在分布式应用中,就得实现序列化,如果不是分布式应用,就没必要实现序列化,因为
1.将对象的状态保存在存储媒体中以便可以在以后重新创建出完全相同的副本
2.按值将对象从一个应用程序域发送至另一个应用程序域
Serializable是一个空接口,目的只是简单的标识一个类的对象可以被序列化
需要序列化的情况
- 当你想把内存中的对象写入到硬盘的时候
内存不够用的时候,计算机就将内存里面的一部分对象暂存到硬盘,等到要用的时候再取出来,硬盘存储的空间就是虚拟内存
- 当你想用套接字在网络上传输对象的时候
有时候传输某一类的对象,有时候就要实现Seriailzable接口,最常见的传输一个字符串,是JDK里面的类,也实现了Serializable接口,所以可以传输
- 当你想通过RMI传输对象的时候
serialVersionUID适用于Java的序列化机制。简单来说,Java的序列化机制是通过判断类的serialVersionUID来验证版本一致性的。在进行反序列化时,JVM会把传来的字节流中的serialVersionUID与本地相应实体类的serialVersionUID进行比较,如果相同就认为是一致的,可以进行反序列化,否则就会出现序列化版本不一致的异常,即是InvalidCastException。
serialVersionUID有两种显示的生成方式:
- 一是默认的1L,比如:private static final long serialVersionUID = 1L;
- 二是根据类名、接口名、成员方法及属性等来生成一个64位的哈希字段,比如: private static final long serialVersionUID = xxxxL;
IDEA配置生成类生成哈希字段的方法
勾选这个按钮
然后生成类的时候放在类名上就可以有 ADD ’SerialVerionUID‘就可以生成了