了解下Java中的Serializable

  在项目中也写了不少的JavaBean,也知道大多的JavaBean都实现了Serializable接口,也知道它的作用是序列化,序列化就是保存,反序列化就是读取。主要体现在这两方面:
1.存储。将程序中的对象保存到文件中,即持久化
2.传输。在网络上传送对象,从一个应用程序域到另一个应用程序域
但是我疑惑的是下面这两点:
1.在项目中的哪方面需要使用Serializable
2.SUID的值的作用是什么
在探索的过程中实现上先解决的是第二个问题。
例 将对象写入到本地文件中:
ObjectOutputStream os = new ObjectOutputStream(new FileOutputStream("D:\\MyDemo\\33.txt")); os.writeObject(stu); os.close();
被写的对象如果实现了Serializable的接口,那么在writeObject()方法中会获取到SUID的值
void writeNonProxy(ObjectOutputStream out) throws IOException { out.writeUTF(name); out.writeLong(getSerialVersionUID());
  这个方法会返回一个SUID,如果JavaBean中已经写了这个serialVersionUID,那么就返回该ID,如果没有,则会根据规则自动生成一个ID。所以SUID的作用就是用来标记序列化前的对象和序列化后的文件是否一致。所以一般的JavaBean都会显示的标明一个SUID,它的值可以是1L,也可以是开发工具自动生成的。
  如果JavaBean中没有显示声明SUID,那么序列化时会使用根据类信息自动生成的一个SUID,只要JavaBean没有发生变化,那么序列化和反序列化是没有问题的。一旦JavaBean发生改变,添加属性或方法,那么根据类信息生成的SUID也会发生改变,此时,之前反序列化的数据就会序列化失败,因为它们的SUID不一致。这就是JavaBean中的SUID为什么要显示声明的原因。
  然后我在项目中就改变了一个用户Bean的SUID,然后Redis就报错了,提示序列化失败,而Reids中存放的是Session信息,在存储的时候会调用JDKSerializableRedisSerializer()方法进行序列化,所以才会提示序列化失败。
  以上,两个问题解决。

posted @ 2019-01-02 15:51  树叶的一生啊  阅读(518)  评论(0编辑  收藏  举报