登录
首页 >  文章 >  java教程

Java序列化反序列化入门教程

时间:2025-11-20 17:10:46 165浏览 收藏

**Java序列化与反序列化语法详解:实现对象持久化的关键技术** 在Java开发中,序列化和反序列化是实现对象持久化的重要机制,它允许将对象状态保存到文件或通过网络传输,并在需要时还原对象。本文将深入解析Java序列化与反序列化的语法规则,包括如何通过实现`Serializable`接口、使用`ObjectOutputStream`和`ObjectInputStream`完成对象的序列化与反序列化操作。同时,本文还将重点讲解`transient`关键字的作用、`serialVersionUID`的定义,以及引用对象的序列化规则等关键注意事项,帮助开发者掌握在Java中安全有效地进行对象序列化和反序列化操作的技能。

序列化和反序列化通过实现Serializable接口、使用ObjectOutputStream和ObjectInputStream完成对象持久化,需注意transient关键字、serialVersionUID定义及引用对象的序列化规则。

Java语法基础中序列化和反序列化的语法规则

序列化和反序列化是Java中实现对象持久化的重要机制。它允许将对象的状态保存到文件或通过网络传输,并在需要时还原对象。要正确使用这一功能,必须遵循特定的语法规则和约定。

实现Serializable接口

要使一个类的对象可序列化,该类必须实现java.io.Serializable接口。这个接口是一个标记接口,不包含任何方法。

示例:

import java.io.Serializable;

public class Person implements Serializable {
    private String name;
    private int age;

    public Person(String name, int age) {
        this.name = name;
        this.age = age;
    }

    // getter和setter方法省略
}

只有实现了Serializable接口的类,其对象才能被ObjectOutputStream写入,否则会抛出NotSerializableException异常。

使用ObjectOutputStream进行序列化

将对象写入文件或字节流时,需使用ObjectOutputStream包装一个输出流(如FileOutputStream)。

基本语法步骤:
  • 创建目标文件的FileOutputStream
  • 用ObjectOutputStream包装该流
  • 调用writeObject()方法写入对象
  • 关闭流资源

import java.io.FileOutputStream;
import java.io.ObjectOutputStream;

Person person = new Person("张三", 25);

try (FileOutputStream fos = new FileOutputStream("person.ser");
     ObjectOutputStream oos = new ObjectOutputStream(fos)) {
    oos.writeObject(person);
} catch (Exception e) {
    e.printStackTrace();
}

使用ObjectInputStream进行反序列化

从文件或字节流中恢复对象,需使用ObjectInputStream包装输入流。

操作流程:
  • 使用FileInputStream读取存储对象的文件
  • 用ObjectInputStream包装该流
  • 调用readObject()方法读取对象,返回Object类型,需强制转换
  • 关闭流

import java.io.FileInputStream;
import java.io.ObjectInputStream;

try (FileInputStream fis = new FileInputStream("person.ser");
     ObjectInputStream ois = new ObjectInputStream(fis)) {
    Person person = (Person) ois.readObject();
    System.out.println(person.getName() + ", " + person.getAge());
} catch (Exception e) {
    e.printStackTrace();
}

序列化注意事项与规则

实际开发中还需注意以下关键点:

  • transient关键字:修饰的字段不会被序列化,适用于密码、临时数据等敏感或无需保存的属性
  • serialVersionUID:建议显式定义,避免因类结构变化导致InvalidClassException
  • 父类序列化:如果父类实现了Serializable,则子类自动继承;若父类未实现,则父类字段不会被序列化
  • 引用对象:对象中包含的其他对象也必须实现Serializable,否则会报错
添加serialVersionUID示例:

private static final long serialVersionUID = 1L;
基本上就这些。掌握这些语法规则后,就能在Java中安全有效地进行对象的序列化和反序列化操作。

本篇关于《Java序列化反序列化入门教程》的介绍就到此结束啦,但是学无止境,想要了解学习更多关于文章的相关知识,请关注golang学习网公众号!

相关阅读
更多>
最新阅读
更多>
课程推荐
更多>