网站首页 > java教程 正文
一、序列化和反序列化的概念
把对象转换为字节序列的过程称为对象的序列化;
把字节序列恢复为对象的过程称为对象的反序列化。
说人话:就是JAVA对象需要保存或通过网络传输必须保存为二进制才行,所以就需要把JAVA对象转换成二进制或二进制会的成JAVA对象。
二、如何使Java类可序列化?
实现java.io.Serializable接口,它是一个标记接口,意味着不包含任何接口和字段。仅用于标识可序列化的语义。
三、代码举例
定义一个JAVA实体类
序列化与化序列化
序列化后的文件
注意:代码演示了一个JAVA类被序列化和反序列化,假设我们尝试去除JAVA类中implements Serializable,再次运行就会出现错误,如下:
四、JAVA类中某些字段不想被序列化怎么办?
在字段中直接加上transient即可,如下图
我们再次运行代码,即可看到如下结果:
五、什么是serialVersionUID?
java序列化机制是通过类的serialVersionUID来验证版本一致性的。在反序列化时,jvm会把传来的字节流中的serialVersionUID和本地相应实体类的serialVersionUID进行比较,如果相同就认为一致,可以进行反序列化,否则出现InvalidCastException异常
模拟一下,我们先把User JAVA类中定义serialVersionUID = 4359709211352400087,然后序列化后再悠serialVersionUID = 1L,再次反序列化,得到如下错误:
再看JVM的代码
五、如何生成serialVersionUID?
一般来说有两种生成方式:
一个是默认的1L,比如:private static final long serialVersionUID = 1L;
一个是根据类名、接口名、成员方法及属性等来生成一个64位的哈希字段,比如:private static final long serialVersionUID = -8940196742313994740L;之类的。
猜你喜欢
- 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)
本文暂时没有评论,来添加一个吧(●'◡'●)