实现Serializable接口是对象序列化的前提,ObjectOutputStream将对象写入文件,ObjectInputStream从文件读取并恢复对象,需注意serialVersionUID一致性、transient与static字段不被序列化,以及类变更时的兼容性处理。

在Java中,ObjectInputStream 和 ObjectOutputStream 是实现对象序列化与反序列化的核心类。它们允许将Java对象转换为字节流,便于存储到文件或通过网络传输,并在需要时还原为原始对象。要正确使用这两个类,必须理解其使用条件和常见注意事项。
实现Serializable接口是前提
要想让一个对象可序列化,其类必须实现 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;
}
@Override
public String toString() {
return "Person{name='" + name + "', age=" + age + "}";
}
}
如果不实现 Serializable 接口,调用 ObjectOutputStream.writeObject() 时会抛出 NotSerializableException。
立即学习“Java免费学习笔记(深入)”;
使用ObjectOutputStream写入对象
通过 FileOutputStream 包装 ObjectOutputStream,可以将对象写入文件。
示例代码:
try (ObjectOutputStream oos = new ObjectOutputStream(new FileOutputStream("person.obj"))) {
Person person = new Person("Alice", 30);
oos.writeObject(person);
System.out.println("对象已序列化");
} catch (IOException e) {
e.printStackTrace();
}
注意:writeObject() 方法可以连续调用写入多个对象,读取时也要按相同顺序读取。
使用ObjectInputStream读取对象
从文件中恢复对象时,使用 ObjectInputStream 配合 FileInputStream。
示例:
try (ObjectInputStream ois = new ObjectInputStream(new FileInputStream("person.obj"))) {
Person person = (Person) ois.readObject();
System.out.println("反序列化的对象:" + person);
} catch (IOException | ClassNotFoundException e) {
e.printStackTrace();
}
readObject() 返回 Object 类型,需强制转换为原类型。ClassNotFoundException 在类路径找不到对应类时抛出。
处理字段变更与serialVersionUID
序列化依赖于类的结构。如果类在序列化后发生改变(如增删字段),反序列化可能失败或出现异常。
建议显式声明 serialVersionUID,避免因JVM自动生成策略不同导致不兼容:
private static final long serialVersionUID = 1L;
当类结构变化但希望保持兼容时,可通过自定义 readObject/writeObject 方法控制序列化过程。
静态字段和瞬态字段的处理
序列化只保存实例状态,以下字段不会被自动序列化:
- static 字段:属于类,不随对象保存
- transient 字段:标记为临时,跳过序列化
若需特殊处理 transient 字段,可在类中定义 private void writeObject(ObjectOutputStream out) 和 private void readObject(ObjectInputStream in) 方法。
基本上就这些。只要类实现 Serializable,使用 ObjectOutputStream 写出、ObjectInputStream 读入,注意 serialVersionUID 和字段控制,就能稳定实现对象持久化。不复杂但容易忽略细节。










