1.序列化是什么?
就是将对象转换成一个字节数组,然后将字节数组转化为原来的对象。
2.序列化怎么实现?
实现Serializable接口(自动序列化)或者继承实现了Serializable接口的类或者实现Externalizable接口(手动序列化)
3.为什么要序列化?
对象存储在JVM里的堆内存中 JVM停止运行 对象就没有了 无法再次使用
想要再次使用怎么办?
就有一个持久化的概念,将对象持久化
序列化:将对象转化为字节数组
反序列化:将字节数组转化为对象
4.对象的持久化(序列化)在Java代码中如何实现呢?
通过io流
输出流:ObjectOutPutStream writeObject方法
输入流:ObjectInputStream readObject方法
5.Java代码实例分析
省略(后续补充)
注意:流的关闭
6.serialVersionUID是什么?什么时候会用到?一定需要他吗?
(1)验证版本是否一致的标识、序列化会写到序列化文件中
(2)序列化的时候会生成一个实体类的serialVersionUID,反序列化的时候 JVM会把字节流中的serialVersionUID和本地对应实体类的serialVersionUID进行比较 一致则反序列化 不一致则会报InvaildCastException异常
(3)不一定需要他
如果你的实体类新增的属性被static修饰的,这个属性就不会被序列化
如果实体类属性被transient修饰,修改transient修饰的值也不会被序列化
总结:
序列化-》反序列化-》修改实体-》反序列化
在序列化和反序列化一次之后,当你修改实体类中的属性时 如果没有指定serialVersionUID,且直接反序列化(将序列化代码注释掉),实体类变更了 生成的UID也会变更 还用之前反序列化的UID就会不一样,报InvaildCastException异常。如果你在之前指定了UID,且直接反序列化 实体类变更了 序列化和反序列化UID还是指定的UID。