理解serialVersionUID

来源:互联网 发布:windows longhorn铃声 编辑:程序博客网 时间:2024/06/04 01:22

理解serialVersionUID

序列化

Java序列化是指把Java对象转换为字节序列的过程;
Java反序列化是指把字节序列恢复为Java对象的过程。

当两个进程进行远程通信时,可以相互发送各种类型的数据,包括文本、图片、音频、视频等, 而这些数据都会以二进制序列的形式在网络上传送。当两个Java进程进行通信时实现进程间的对象传送,就需要Java序列化与反序列化了。换句话说,发送方需要把这个Java对象转换为字节序列,然后在网络上传送;另一方面,接收方需要从字节序列中恢复出Java对象。

serialVersionUID

Java的序列化机制是通过在运行时判断类的serialVersionUID来验证版本一致性的。在进行反序列化时,JVM会把传来的字节流中的serialVersionUID与本地相应实体(类)的serialVersionUID进行比较,如果相同就认为是一致的,可以进行反序列化,否则就会出现序列化版本不一致的异常。(InvalidCastException)

serialVersionUID有两种显示的生成方式:
1. 一个是默认的1L,比如:private static final long serialVersionUID = 1L;
2. 一个是根据类名、接口名、成员方法及属性等来生成一个64位的哈希字段,比如: private static final long serialVersionUID = xxxxL; 当你一个类实现了Serializable接口,如果没有显示的定义serialVersionUID,Eclipse会提供提示功能告诉你去定义 。

  • 问题一:假设有A端和B端,如果2处的serialVersionUID不一致,会产生什么错误呢?

    1)先执行测试类SerialTest,然后修改serialVersion值(或注释掉serialVersion并编译),再执行测试类DeserialTest,报错:
    java.io.InvalidClassException: com.test.serializable.Serial; local class incompatible: stream classdesc serialVersionUID = 1, local class serialVersionUID = 11
    2)A端和B端都没显示的写serialVersionUID,实体类没有改动(如果class文件(类名,方法明等)没有发生变化(增加空格,换行,增加注释,等等),).序列化,反序列化正常.

  • 问题二:假设2处serialVersionUID一致,如果A端增加一个字段,B端不变,会是什么情况呢?

  • 问题五:假设2处serialVersionUID一致,如果B端减少一个字段,A端不变,会是什么情况呢?

    序列化,反序列化正常,A端增加的字段丢失(被B端忽略).

  • 问题三:假设2处serialVersionUID一致,如果B段增加一个字段,A端不变,会是什么情况呢?

  • 问题四:假设2处serialVersionUID一致,如果A端减少一个字段,B端不变,会是什么情况呢?(与问题三类似,四答案:序列化,反序列化正常,B端字段多余A端,B端多出的字段被赋予对应类型的默认值)

    序列化,反序列化正常,B端新增加的int字段被赋予了默认值0.

原创粉丝点击