什么是 java 序列化?什么情况下需要序列化?
-
定义:序列化就是把一个对象的状态输出到byte stream中,然后可以通过反序列化,即在byte stream读出对象的状态,来恢复成实例对象
-
我们可以自己定义实例对象在输出的时候的规则(也即是序列化),例如那个字段不输出,字段输出的顺序,输出字段数据之间用什么来间隔,但我们可以通过实现
Seriablizable
接口或者其子接口Externalizable
接口来使的类变成可序列化(serializable),可序列化的类具有默认的序列化的规则(即输出或者输入的规则) -
默认的序列化的规则
- static,transient修饰的field不序列化
- 类中associated Object也需要实现
Serializable
接口 - 父类实现
Serializalbe
接口,子类就不用实现啦 - 在反序列化的过程中,构造函数没有被调用
-
SerialVersionUID
-
what:在序列化的时候,该SerialVersionUID与已序列化的对象(输出)关联以来,在反序列化的时候,可以用这个SerialVersionUID来验证其接收方加载的class definition是否跟已序列化的对象是否兼容
-
how:定义SerialVersionUID有一下的规则
- static,final,long
-
注意点
-
如果没有自定义SerialVersionUID,则在serialization time时,会计算生成一个默认的SerialVersionUID
-
推荐自定义SerialVersionUID,因为由于它的计算对可能因编译器实现而不同的类细节高度敏感,因此类中的任何更改或使用不同的id都可能影响序列化数据
-
推荐在自定义SerialVersonUID的时候,使用private modifier,因为即使其被继承下来,也不能作为子类的SerialVersionUID
-
-
-
还有更多有关于序列化的知识,请看下面的参考资料
-
参考资料
- https://docs.oracle.com/javase/tutorial/jndi/objects/serial.html
- https://docs.oracle.com/javase/8/docs/technotes/guides/serialization/index.html
- https://www.geeksforgeeks.org/serialization-in-java/