序列化
Serializable 序列化一直是我迷惑的地方,在我开始开发工作时,entity基类都实现了序列化接口,现在总算找到机会了解下了。
jdk api 文档里面关于接口 Serializable 的描述:
类通过实现 java.io.Serializable 接口以启用其序列化功能。
未实现此接口的类将无法使其任何状态序列化或反序列化。
可序列化类的所有子类型本身都是可序列化的。因为实现接口也是间接的等同于继承。
序列化接口没有方法或字段,仅用于标识可序列化的语义。
序列化的概念
Java提供一种机制叫做序列化,通过有序的格式或者字节序列持久化java对象,其中包含对象的数据,还有对象的类型,和保存在对象中的数据类型,反之就是反序列化。
其实就是将对象写入IO流的过程。
序列化的意义: 序列化机制允许将实现序列化的Java对象转换位字节序列,这些字节序列可以保存在磁盘上,或通过网络传输,以达到以后恢复成原来的对象。序列化机制使得对象可以脱离程序的运行而独立存在。
序列化的使用场景
- 当你想把的内存中的对象状态保存到一个文件中或者数据库中时候;
- 当你想用套接字在网络上传送对象的时候;
- 当你想通过RMI(remote method invoke,即远程方法调用)传输对象的时候;
通常建议:程序创建的每个JavaBean类都实现Serializeable接口。
序列化的底层原理
底层原理移步大神的文章:https://blog.csdn.net/weixin_39723544/article/details/80527550
若无法访问,还留有截图:https://github.com/pic_bed_of_shiva/static-resources/blob/master/showns/images/SerializablePrinciple.png
serialVersionUID 的作用和用法
serialVersionUID 是用于保证同一个对象(在序列化中会被用到)可以在Deserialization过程中被载入。serialVersionUID 是用于对象的版本控制。
例如,随着项目升级,class文件也会升级,serialVersionUID 就是保证升级后的class对应关系,即使更改了序列化属性,也能反序列回来。
序列化版本号可自由指定,如果不指定,JVM会根据类信息自己计算一个版本号,这样随着class的升级,就无法正确反序列化;
不指定版本号另一个明显隐患是,不利于jvm间的移植,可能class文件没有更改,但不同jvm可能计算的规则不一样,这样也会导致无法反序列化。
其他注意事项
-
static 和 transient 修饰的字段是不会被序列化的 。
不想某字段被序列化,就加上 transient 修饰。这也是修饰后数据库不会做这个字段的映射,,ORM框架将忽略该属性,序列化过程忽略了这个字段。
-
序列化对象的引用类型成员变量,也必须是可序列化的,否则,会报错。
-
同一对象序列化多次,只有第一次序列化为二进制流,以后都只是保存序列化编号,不会重复序列化。
序列化部分参考文章
https://www.cnblogs.com/9dragon/p/10901448.html
https://www.cnblogs.com/qq3111901846/p/7894532.html
https://blog.csdn.net/weixin_39723544/article/details/80527550
https://blog.csdn.net/u013870094/article/details/82765907
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/10334.html