在面试中我常常会考察Serializable相关的问题,我认为这是一个很基础的知识点,是对候选人基础是否扎实的考察。但是结果有点出乎意料,候选人往往只是知道它和序列化有关,而对于其中的细节以及更深层次的原理都不是很清楚。因此,我决定整理一下Serializable相关的一些问题,希望能够对不了解的同学有所帮助。
一个类实现Serializable接口后可以被序列化。这个接口没有方法和字段,只是用来标志这个类可以被序列化。
关于serialVersionUID
一个类如果实现了Serializable接口,同时也需要定义一个serialVersionUID,如下:
private static final long serialVersionUID = 1L;
我相信很多同学一直不太明白这个 serialVersionUID 字段的真正作用,如果我们不去定义它会有什么样的问题。
serialVersionUID按照字面意思来理解就是序列化的版本号,这个serialVersionUID是用来辅助对象的序列化与反序列化的,原则上序列化后的数据当中的serialVersionUID与当前类中的serialVersionUID一致,该对象才能被反序列化成功。
这个serialVersionUID的工作原理大致是这样的:在序列化的时候系统将serialVersionUID写入到序列化的文件中去,反序列化的时候系统会先去检测文件中的serialVersionUID是否跟当前的serialVersionUID一致,如果一致就反序列化成功,否则就说明当前类跟序列化后的类发生了变化,反序列化时就会发生crash,并且会抛出异常: