答案:ObjectInputStream和ObjectOutputStream用于Java对象序列化与反序列化,要求类实现Serializable接口,使用transient修饰非序列化字段,显式定义serialVersionUID;通过writeObject和readObject方法实现对象持久化与恢复,注意static和transient字段不参与序列化,反序列化不调用构造方法。

在Java中,ObjectInputStream 和 ObjectOutputStream 是用于实现对象序列化和反序列化的核心类。它们允许将Java对象转换为字节流,便于存储到文件或通过网络传输,并能从字节流中恢复原始对象。
对象序列化的基本要求
要使一个对象可序列化,必须满足以下条件:
- 类必须实现 java.io.Serializable 接口(标记接口,无需实现方法)
- 对象的所有成员变量也必须是可序列化的,否则需要使用 transient 关键字修饰
- serialVersionUID 建议显式定义,避免版本不兼容问题
示例类:
public class Person implements Serializable {
private static final long serialVersionUID = 1L;
private String name;
private int age;
private transient String password; // 不参与序列化
public Person(String name, int age, String password) {
this.name = name;
this.age = age;
this.password = password;
}
@Override
public String toString() {
return "Person{name='" + name + "', age=" + age + ", password='" + password + "'}";
}
}
使用ObjectOutputStream写入对象
通过 ObjectOutputStream 可以将对象写入输出流,通常结合文件流使用。
立即学习“Java免费学习笔记(深入)”;
try (ObjectOutputStream oos = new ObjectOutputStream(new FileOutputStream("person.obj"))) {
Person person = new Person("张三", 25, "123456");
oos.writeObject(person);
System.out.println("对象已序列化保存");
} catch (IOException e) {
e.printStackTrace();
}
- writeObject(Object obj) 方法将对象写入底层流
- 建议使用 try-with-resources 自动关闭资源
使用ObjectInputStream读取对象
通过 ObjectInputStream 可以从输入流中恢复对象。
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 类型,需强制转换
- 如果类未找到或序列化版本不匹配,会抛出异常
常见注意事项
- static 和 transient 字段不会被序列化
- 反序列化时不会调用构造方法,而是由JVM创建对象
- 多个对象写入同一个流时,需按顺序读取
- 集合类如 ArrayList、HashMap 等都实现了 Serializable,可直接序列化
基本上就这些。掌握 ObjectInputStream 和 ObjectOutputStream 的使用,就能实现Java对象的持久化和跨网络传递。关键是确保类正确实现 Serializable,处理好异常,并注意字段的序列化行为。不复杂但容易忽略细节。










