序列化和反序列化通过实现Serializable接口、使用ObjectOutputStream和ObjectInputStream完成对象持久化,需注意transient关键字、serialVersionUID定义及引用对象的序列化规则。
序列化和反序列化是Java中实现对象持久化的重要机制。它允许将对象的状态保存到文件或通过网络传输,并在需要时还原对象。要正确使用这一功能,必须遵循特定的语法规则和约定。
要使一个类的对象可序列化,该类必须实现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包装一个输出流(如FileOutputStream)。
基本语法步骤:
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包装输入流。
操作流程:
eInputStream读取存储对象的文件
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();
}
实际开发中还需注意以下关键点:
private static final long serialVersionUID = 1L;基本上就这些。掌握这些语法规则后,就能在Java中安全有效地进行对象的序列化和反序列化操作。