Java序列化就是将一个对象转化成一串二进制表示的字节数组,通过保存或转移这些字节数据来达到持久化的目的。需要持久化,对象必须实现
java.io.Serializable 接口。反序列化则是相反的过程,将这个字节数组再重新构造成对象。反序列化时,必须有原始类作为模板,才能将这个对象还原,从
这个过程我们可以猜测,序列化的数据并不像class 文件那样保存类的完整的结构信息。 那么序列化的数据到底都含有哪些信息?
虽然Java的序列化能够保证对象状态的持久保存,但是遇到一些对象结构复杂的情况还是比较难处理的,下面是对一些复杂的对象情况的总结:
1. 当父类实现Serializable 接口时,所有子类都可以被序列化
2.子类实现了Serializable 接口,父类没有,父类中的属性不能序列化(不报错,但数据会丢失),但是在子类中属性仍能正确序列化。
3.如果序列化的属性是对象,则这个对象也必须实现Serialiazable接口,否则会报错。
4.在反序列化时,如果对象的属性有修改或删减,则修改的部分属性会丢失,但不会报错。
5.在反序列化时,如果serialVersionUID被修改,则反序列化时会失败。
在纯Java环境下,Java序列化能够很好的工作,但是在多语言环境下,用Java序列化存储后,很难用其他语言还原出结果。在这种情况下,还是要尽量存储通用
的数据结构,如JSON或者XML结构数据,当前也有比较好的序列化工具,如Google的protobuf等。