常常见到这样一句话:一个类只有实现了Serializable接口,它的对象才能被序列化。
那么什么是序列化?
序列化是将对象状态转换为可保持或传输的格式的过程。与序列化相对的是反序列化,它将字节流转换为对象。这两个过程结合起来,可以轻松地存储和传输数据。
为什么要序列化对象?
当我们需要把对象的状态信息通过网络进行传输,或者需要将对象的状态信息持久化,以便将来使用时都需要把对象进行序列化。
那么为什么要实现Serializable接口呢?
其实在Serializable接口里面什么都没有,只是个空接口。
一个接口里面什么内容都没有,我们可以将它理解成一个标识接口。
比如在课堂上有位学生遇到一个问题,于是举手向老师请教,这时老师帮他解答,那么这位学生的举手其实就是一个标识,自己解决不了问题请教老师帮忙解决。在Java中的这个Serializable接口其实是给JVM看的,通知JVM,我不对这个类做序列化了,你(JVM)帮我序列化就好了。
Serializable接口就是Java提供用来进行高效率的异地共享实例对象的机制,实现这个接口即可。
为什么要定义serialversionUID变量?
看一下 Serializable接口的说明:
如果我们没有自己声明一个serialVersionUID变量,接口会默认生成一个serialVersionUID。
但是强烈建议用户自定义一个serialVersionUID,因为默认的serialVersinUID对于class的细节非常敏感,反序列化时可能会导致InvalidClassException这个异常。
如果将serialVersionUID变量去掉,
这个serialVersionUID是用来辅助对象的序列化与反序列化的,原则上序列化后的数据当中的serialVersionUID与类当中的serialVersionUID一致,那么该对象才能被反序列化成功。
这个serialVersionUID的详细工作机制是:在序列化的时候系统将serialVersionUID写入到字节流中去,当反序列化的时候系统会先去检测字节流中的serialVersionUID是否跟类的serialVersionUID一致,如果一致则反序列化成功,否则就说明序列化后发生了变化,那么在反序列化时就会产生异常。