Java序列化和反序列化踩坑实记
——Javee
先分别看看序列化和反序列化的代码:
// 序列化
public static void main(String[] args) throws Exception {
Student student = Student.getStudent(); //单例模式获取对象
File file = new File("d:/student.txt");
file.createNewFile();
ObjectOutputStream oos = new ObjectOutputStream(new FileOutputStream(file));
oos.writeObject(student); //将对象序列化写入文件
oos.flush();
oos.close();
}
//反序列化
System.out.println("开始反序列化");
File file = new File("d:/student.txt");
ObjectInputStream ois = new ObjectInputStream(new FileInputStream(file));
Student searializeStu = (Student)ois.readObject();
System.out.println(searializeStu);
序列化和反序列化需要注意以下几点:
-
对象所属的类必须实现Serializable接口.
-
如果被序列化的对象中,包含了其他对象, 那么这个其他对象所在的类也要实现Serializable接口
-
对象中,如果有被transient修饰的成员变量不参与序列化过程
-
静态属性也不参与序列化
-
序列化完成后,如果更改类的属性,再去进行反序列化的时候就会抛出异常(除非在类里面明确给出serialVersionUID的值,或者重新序列化)
serialVersionUID是什么:
Java在进行反序列化的时候,会根据类的属性和方法计算出一个值,这个值就是serialVersionUID,将反序列化出来的对象计算出来的serialVersionUID和通过类属性和方法计算出来的serialVersionUID进行对比,如果不相等,就会抛出异常。程序员可以自己声明serialVersionUID来显式声明其自己的 serialVersionUID(必须是long static final修饰的字段)
serialVersionUID存在的意义为了使新版本兼容老版本的数据