网站首页 > java教程 正文
喜欢就关注小编,小编天天写,你也可以进步一点点
java中的对象流
ObjectOutputStream对象字节输出流(序列化)(串行化)
对象字节输出流可以将Java对象转换成二进制写入磁盘,这个过程通常叫做序列化,并且还可以从磁盘读出完整的Java对象,而这个过程叫做反序列化。对象流主要包括:ObjectInputStream和ObjectOutputStream。
需要注意的是,实现序列化的类必须实现序列化接口java.io.Serializable,该接口没有任何方法,只是一种标记接口,标记这个类是可以被序列化的。
案例:将User对象序列化到磁盘
ObjectInputStream对象字节输入流(反序列化)(反串行化)
将序列化的Java对象返序列化到内存中,
案例:将序列化后的Java对象反序列化到内存,并输出对象信息
ObjectOutputStream和ObjectInputStream与序列化版本号
实现了java.io.Serializable接口的类的对象可以被序列化,当Java虚拟机发现这个类实现了Serializable接口,会给这个类添加一个属性serialVersionUID,序列化版本号,目的是保证序列化后如果进行反序列化时,根据类的版本号判断类中的代码是否进行过修改,保证类没有发生改变。增加代码或修改代码在反序列化是会产生新的序列化版本号。如果类中的代码发生改变,反序列化的过程将抛出异常。异常信息如下:
String类的序列化版本号属性
private static final long serialVersionUID = -6849794470754667710L;
没有手动添加序列号版本号属性serialVersionUID,系统会默认添加一个,并赋值,如果参加序列化的类中代码发生了修改,系统会重写创建一个序列化版本号。
喜欢就关注小编,小编天天写,你也可以进步一点点
- 上一篇: 什么是反序列化?反序列化的过程,原理
- 下一篇: 什么是Java序列化?什么是Java反序列化?
猜你喜欢
- 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)
本文暂时没有评论,来添加一个吧(●'◡'●)