1、序列化:将一个对象编码成字节流,反序列化:将字节流编码重构成对象;
2、序列化版本号serialVersionUID:
没有设置这个值的时候,会有一个默认的(根据类名、接口名、成员名来生成),后续如果有变动默认的uid会不同,兼容性会受到影响。InvalidClassException
3、序列化可能够破坏对象内部的约束关系;
4、Date、BigInteger(值类)和集合需要serializable,线程池一般不需要;
5、transient
a、类中的字段值可以根据其它字段推导出来;
b、根据业务需求,设置字段不想被序列化;
6、子类与父类序列化区别:
a. 如果子类实现Serializable接口而父类未实现时,父类不会被序列化!
b. 如果父类实现序列化,子类自动实现序列化,不需要显式实现Serializable接口。
序列化与反序列化详解
本文详细介绍了序列化和反序列化的概念,探讨了序列化版本号serialVersionUID的作用及未设置时可能引发的InvalidClassException。分析了序列化可能破坏对象内部约束,并明确了Date、BigInteger等值类和集合需实现serializable接口,而线程池通常不需序列化。此外,还解释了transient关键字的使用场景,以及子类与父类在序列化过程中的差异。
4057

被折叠的 条评论
为什么被折叠?



