我的网站 | 我的博客 | 序列化解析工具
概念
Java为我们提供了一种默认的对象序列化机制,通过这种机制可以将一个实例对象写入到IO流中,当然这种IO流可以是文件流、网络流或者其他什么流。
代码的写法
- ObjectOutputStream 对象输出流,用于序列化一个对象
- ObjectInputStream 对象输入流,用于反序列化一个对象
- Serializable 和 Externalizable 只有实现其中一个接口的类的对象才能被序列化
注1:Externalizable 是序列化的一个扩展接口,它本身继承了Serializable接口。实现Externalizable接口的对象在序列化和反序列化时会用 writeExternal 和readExternal 方法替换默认的处理逻辑
注2: 反序列化时 serialVersionUID 的值必须和序列化时的一致,否则反序列报错失败
将对象序列化到文件流中
String file = "string3.out";
ObjectOutputStream outputStream = new ObjectOutputStream(new FileOutputStream(file));
TestObject testObject = new TestObject();
testObject.setContent("test");
outputStream.writeObject(testObject);
从文件流中反序列化
String file = "string3.out";
ObjectInputStream in = new ObjectInputStream(new FileInputStream(file));
TestObject responseBean = (TestObject) in.readObject();
System.out.println(responseBean.getContent());
两种实现方式
1、实现 Serializable 接口
@Setter
@Getter
public class TestObject extends UnicodeRequest implements Serializable {
private static final long serialVersionUID = 5347411908895007509L;
private String content;
}
2、实现 Externalizable 接口
@Setter
@Getter
public class TestObject extends UnicodeRequest implements Externalizable {
private static final long serialVersionUID = 5347411908895007509L;
private String content;
@Override
public void writeExternal(ObjectOutput out) throws IOException {
out.writeUTF(this.content);
}
@Override
public void readExternal(ObjectInput in) throws IOException, ClassNotFoundException {
this.conent = in.readUTF();
}
}
五种特殊的方法
如果被序列化对象实现了以下5种特殊的方法,会影响序列化或反序列化时原有的行为。
以下1个特殊的方法 用于序列化和反序列化的对像替换,常用于单例对象的序列化,保证单例的绝对安全。
ANY-ACCESS-MODIFIER Object readResolve() throws ObjectStreamException;
ANY-ACCESS-MODIFIER Object writeReplace() throws ObjectStreamException;
以下3个特殊的方法 用于替换默认的序列化行为。
注:如果对象实现了Externalizable接口,下边的方法就不在有作用了。
private void writeObject(java.io.ObjectOutputStream out) throws IOException;
private void readObject(java.io.ObjectInputStream in) throws IOException, ClassNotFoundException;
private void readObjectNoData() throws ObjectStreamException;
序列化原理
Type Code
type code | 说明 |
---|---|
B | byte |
C | char |
D | double |
F | float |
I | int |
J | long |
L | class or interface |
S | short |
Z | boolean |
[ | array |