//不用序列化:啥时候用到序列化和反序列化
- 序列化会有一个默认的常量,单个系统没有影响
- 前台会被后台调用
- 项目会被拆分 前台8091 后台8092 两个端口
- 怎么进行调用两个项目中的对象,要进行穿参就需要进行序列化反序列化
- 前台把用户数据收集好以后通过网络传递给后台,内部有一种传输协议规则rpc协议
- 好处http传递的是字符串,而rpc传递的是对象,不能再网络中直接传输,需要序列化反序列化转换成字符传输
- 再进行序列化的时候有名字序列化编号属性
就像一个列车1user 2.1l 3.属性 4.属性的值 5.方法 这就是对象的序列化的字符编码方式
有时需要为对象做持久化,就是把内存里的对象保存到磁盘(暂且叫做磁盘吧,可以等同于sp、db、文件、网络等)上,等以后需要这个对象的时候再从磁盘上还原到内存,因此需要序列化和反序列化。
如果使用ObjectOutputStream方式序列化,可能出现的坑如下:
坑1、类里面一定要serialVersionUID,否则旧数据会反序列化会失败。
serialVersionUID是根据该类名、方法名等数据生产的一个整数,用来验证版本是否一致。
如果不加这个字段,当你的类修改了字段,在反序列化的时候会直接报异常:InvalidCastException,导致无法完成反序列化。
举个例子:类A没有添加serialVersionUID,代码里有序列化和反序列化逻辑,app匆匆发版了。然后某一天由于需求变动,在类A里面增加了一个字段变成了类AA,再次发版,当新用户更新app后,使用反序列化以前的数据时,直接报异常。
坑2、一旦序列化保存到磁盘操作后,就不要修改类名了,否则旧数据会反序列化会失败。
举个例子
所以尽量把对象转换成JSON保存更稳妥。