保存对象的过程:保存对象的类型,然后保存定义对象当前状态的数据。
读取对象的过程:读取对象类型,创建该类型的一个空白对象,在该空白对象中填充保存在文件中的数据。
我们希望磁盘上的对象布局和内存中的对象布局保持一致。在面向对象程序设计中这种情况为"持续性"(persistence).
对象序列化机制:保存到磁盘的所有对象都获得一个序列号(作为对象的类型标识,可以用于SDK一起提供serialver程序获得该值),当要保存一个对象时先检查该对象是否已经被保存了,如果保存过就只须写入“与已经保存的具有序列号x的对象相同”的信息,否则保存它的所有数据。
就技术而言,只要类的数据布局没有改变,读取一格对象就应该是安全的。但Java相对保守,还要检验它的方法是否被改变。(毕竟,方法是用来表示被保存数据的意义)。
另外,如果要新版本的程序兼容旧文件保存的对象(星版本中该对象的类已经被修改过)的做法是在类中添加一个名为serialVersionUID的静态数据成员(public static final long seerialVersionUID = ...),把它符值为一开始的序列号(可以通过serialver得到,前面有介绍),那么它不会在计算序列号(即指纹),而是使用这个值。
以上内容主要来自Java核心技术卷一