简单来说JAVA序列化就是实现一个@Serializable接口的JAVA类,其过程是将JAVA对象编码成二进制字节码(反序列化:将二进制字节码解码成JAVA对象)
为什么需要序列化?
1、在JVM停止运行时,持久化JAVA对象
2、进行网络传输,因为网络传输只能发送和接受二进制码流,因此需要通过对象序列化与反序列将整个JAVA对象传输给远程
使用方法
实现@Serializable接口,创建一个唯一标示号serialVersionUID与该可序列化类相关联,并通过ObjectInputStream与ObjectOutputStream的writeObject()方法进行对象操作,提供序列化类的自定义readObject()方法,调用defaultReadObject(),编写有效性检查。
Other
对于单例类Singleton,如果实现了@Serializable接口,那么它就不再是一个Singleton,readObject默认会返回一个新建实例
要保证其Singleton属性,需要在readResolve()中返回对应INSTANCE,但是该依赖导致所有所有对象引用类型的实例域都要声明成transient