java序列化类的多版本问题

¨解读: 

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自动生成 

你可能感兴趣的:(java,eclipse,jvm,String,object,Class)