网站首页 > java教程 正文
前言:在回答上面的问题之前,首先要知道什么是序列化、反序列化、用途是什么、实现的必要条件。
序列化\反序列化:java序列化是指把java对象转换为字节序列的过程,而java反序列化是指把字节序列恢复为java对象的过程。
用途:当两个进程进行远程通信时,可以相互发送各种类型的数据,包括文本,图片,音频,视频等,而这些数据都会以二进制的形式在网络上传送;当两个java进行进行通信时,要传送对象,怎么传对象,通过序列化与反序列化;永久性保存对象,保存对象的字节序列到本地文件或者数据库中,实现了数据的持久化;利用序列化实现远程通信,可以在网络上传送对象的字节序列;在进程间传递对象。
实现的必要条件:只有实现了Serializable或Externalizable接口的对象才能被序列化,否则抛出异常。
如图:当User没有实现Serializable,对他进行序列化时会报NotSerializableException异常
如何实现呢,通过FileOutputStream的writeObject实现序列化,通过FileInputStream的readObject实现反序列化。如图:
这面这些希望大家了解,面试时会被问到的!
但是我上面的User没有定义serialVersionUID也照样实现了序列化、反序列,似乎这个serialVersionUID没有什么用,而事实真的是这样吗。通过查阅资料发现Java的序列化机制是通过判断类的serialVersionUID来验证版本一致性的。
serialVersionUID有两种显示的生成方式:①是默认的1L;②根据类名、接口名、成员方法及属性等来生成一个64位的哈希字段。
有人会疑问为什么我没有定义serialVersionUID也会成功。因为当实现Serializable接口的类没有显式地定义一个serialVersionUID变量时候,Java序列化机制会根据编译的Class自动生成一个serialVersionUID作序列化版本比较用,这种情况下,如果Class文件(类名,方法明等)没有发生变化(增加空格,换行,增加注释等等),就算再编译多次,serialVersionUID也不会变化的,此种方式是不兼容的。
这里我验证下序列化后,我改变User的serialVersionUID的值,如图:
总结:
Java序列化机制会根据编译的Class自动生成一个serialVersionUID作序列化版本,这种方式是不兼容的,比如User序列化后,再增加一个字段age2,反序列化获取,会报版本错误。如果User中定义了serialVersionUID,则会返回一个默认值。所以我个人还是建议在实现Serializable时要定义serialVersionUID。
猜你喜欢
- 2024-11-04 快速处理Kafka反序列化错误(kafka自定义反序列化)
- 2024-11-04 又一个反序列化漏洞,我服了...(反序列化漏洞修复方案)
- 2024-11-04 Java代码示例:如何使用 serialVersionUID处理序列化
- 2024-11-04 Java 序列化机制(java序列化过程)
- 2024-11-04 SpringBoot整合Grpc实现跨语言RPC通讯
- 2024-11-04 php和java及python3.10的序列化和反序列化
- 2024-11-04 Java修炼终极指南:133 避免在反序列化时发生DoS攻击
- 2024-11-04 聊聊fastjson反序列化的那些坑(fastjson反序列化原理)
- 2024-11-04 Java序列化 3 连问,这太难了吧(在线序列化工具)
- 2024-11-04 避免使用Java序列化(serializable 防止序列化)
你 发表评论:
欢迎- 最近发表
- 标签列表
-
- java反编译工具 (77)
- java反射 (57)
- java接口 (61)
- java随机数 (63)
- java7下载 (59)
- java数据结构 (61)
- java 三目运算符 (65)
- java对象转map (63)
- Java继承 (69)
- java字符串替换 (60)
- 快速排序java (59)
- java并发编程 (58)
- java api文档 (60)
- centos安装java (57)
- java调用webservice接口 (61)
- java深拷贝 (61)
- 工厂模式java (59)
- java代理模式 (59)
- java.lang (57)
- java连接mysql数据库 (67)
- java重载 (68)
- java 循环语句 (66)
- java反序列化 (58)
- java时间函数 (60)
- java是值传递还是引用传递 (62)
本文暂时没有评论,来添加一个吧(●'◡'●)