一. 序列化的作用?
- 实现了Java 对象的持久化,通过序列化可以把数据永久地保存到硬盘上(通常存放在文件里)或者db中。
- 利用序列化实现远程通信,即在网络上传送对象的字节序列。
二. 概念?
序列化是把对象的状态信息转化为可存储或传输的形式过程,也就是把对象转化为字节序列的过程称为对象的序列化。
反序列化是序列化的逆向过程,把字节数组反序列化为对象,把字节序列恢复为对象的过程成为对象的反序列化。
java是输入输出流实现的,ObjectOutputStream和ObjectInputStream,wirteObject序列化转化成输出流,readObject反序列化将输入流恢复成对象
三. serialVersionUID?
Java 的序列化机制是通过判断类的 serialVersionUID 来验证版本一致性的。在进行反序列化 时,JVM 会把传来的字节流中的 serialVersionUID 与本地相应实体类的serialVersionUID进行比较,如果相同就认为是一致的,可以进行反序列化,否则就会出现序列化版本不一致的 异常,即是 InvalidCastException。
- 默认 1L,比如:private static final long serialVersionUID = 1L
- 根据类名、接口名、成员方法及属性等来生成一个64位的哈希字段
当实现 java.io.Serializable 接口的类没有显式地定义一个 serialVersionUID 变量时候,Java 序 列化机制会根据编译的Class自动生成一个serialVersionUID作序列化版本比较用,这种情况下,如果Class文件(类名,方法明等)没有发生变化(增加空格,换行,增加注释等等),就算再编译多次,serialVersionUID也不会变化的。
四. Java序列化的一些简单总结?
- Java 序列化只是针对对象的状态进行保存,至于对象中的方法,序列化不关心
- 当一个父类实现了序列化,那么子类会自动实现序列化,不需要显示实现序列化接口
- 当一个对象的实例变量引用了其他对象,序列化这个对象的时候会自动把引用的对象也进行序列化(实现深度克隆)
- 当某个字段被申明为static(修饰的成员变量属于类)或者transient 后,默认的序列化机制会忽略这个字段
- 被申明为 transient 的字段,如果需要序列化,可以添加两个私有方法:writeObject和readObject