在Java中,序列化(Serialization)是将对象转换为字节序列的过程,而反序列化(Deserialization)则是将字节序列转换回对象的过程。序列化和反序列化主要用于在网络上传输对象或将对象持久化到磁盘上。
Java提供了 java.io.Serializable 接口,通过实现这个接口,类的对象可以被序列化。要进行序列化和反序列化,可以使用Java提供的 ObjectOutputStream 和 ObjectInputStream 类。
以下是序列化和反序列化的基本步骤:
序列化(Serialization):
- 实现 Serializable 接口:在要进行序列化的类上实现 Serializable 接口。
import java.io.Serializable;
public class MyClass implements Serializable {
// 类的成员和方法
}
- 创建 ObjectOutputStream 对象:使用 ObjectOutputStream 类创建一个输出流。
import java.io.FileOutputStream;
import java.io.ObjectOutputStream;
FileOutputStream fileOut = new FileOutputStream("file.ser");
ObjectOutputStream out = new ObjectOutputStream(fileOut);
- 将对象序列化:使用 writeObject() 方法将对象写入输出流。
MyClass obj = new MyClass();
out.writeObject(obj);
- 关闭流:关闭输出流。
out.close();
fileOut.close();
反序列化(Deserialization):
- 创建 ObjectInputStream 对象:使用 ObjectInputStream 类创建一个输入流。
import java.io.FileInputStream;
import java.io.ObjectInputStream;
FileInputStream fileIn = new FileInputStream("file.ser");
ObjectInputStream in = new ObjectInputStream(fileIn);
- 从流中读取对象:使用 readObject() 方法从输入流中读取对象。
MyClass obj = (MyClass) in.readObject();
- 关闭流:关闭输入流。
in.close();
fileIn.close();
需要注意的是,要序列化的类必须实现 Serializable 接口,否则会抛出 NotSerializableException。此外,序列化并不保存静态变量的状态。