答案:ObjectInputStream和ObjectOutputStream用于Java对象序列化与反序列化,要求类实现Serializable接口,使用transient修饰非序列化字段,显式定义serialVersionUID;通过writeObject和readObject方法实现对象持久化与恢复,注意static和transient字段不参与序列化,反序列化不调用构造方法。
在Java中,ObjectInputStream 和 ObjectOutputStream 是用于实现对象序列化和反序列化的核心类。它们允许将Java对象转换为字节流,便于存储到文件或通过网络传输,并能从字节流中恢复原始对象。
要使一个对象可序列化,必须满足以下条件:

示例类:
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 可以将对象写入输出流,通常结合文件流使用。
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();
}
通过 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();
}
基本上就这些。掌握 ObjectInputStream 和 ObjectOutputStream 的使用,就能实现Java对象的持久化和跨网络传递。关键是确保类正确实现 Serializable,处理好异常,并注意字段的序列化行为。不复杂但容易忽略细节。