解读:
Java的序列化机制是通过在运行时判断类的serialVersionUID来验证版本一致性的。在进行反序列化时,JVM会把传来的字节流中的serialVersionUID与本地相应实体(类)的serialVersionUID进行比较,如果相同就认为是一致的,可以进行反序列化,否则就会出现序列化版本不一致的异常。当实现java.io.Serializable接口的实体(类)没有显式地定义serialVersionUID时,Java序列化机制会根据编译的class自动生成一个serialVersionUID作序列化版本比较用,这种情况下,只有同一次编译生成的 class才会生成相同的serialVersionUID
案例:
不好的写法:
程序一:
简单的可序列化的Bean
import java.io.Serializable;
public class TestSave implements Serializable
{
private String name;
public String getName()
{
return name;
}
public void setName( String name )
{
this.name = name;
}
}
程序二:
写一个程序,创建一个对象,并将它序列化到文件
TestSave t = new TestSave();
t.setName("Litian");
ObjectOutputStream o = new ObjectOutputStream(new FileOutputStream("test.dat"));
o.writeObject(t);
o.close();
上面的程序会成功打印出Litian
这个字符串。但如果给程序一新
增方法后,程序会由于
serialVersionUID不一致而出错,
所以可以在程序一生成一个
serialVersionUID属性,这样运行
就不会出错。
程序三:
将序列化到文件中的对象读出来
ObjectInputStream in = new ObjectInputStream
(new FileInputStream("test.dat"));
Object obj = in.readObject();
TestSave t1 = (TestSave) obj;
System.out.println(t1.getName());
正确的写法:
在程序1生成一个serialVersionUID属性,即,加一行:
private static final long serialVersionUID = 8884304697323578107L;//可由eclipse自动生成