使用ObjectInputStream和ObjectOutPutStream读写类必须实现serializable接口,将实现了该接口的对象转换为一个字节序列,并在以后可以将这个字节序列恢复成原来的对象。
什么时候需要使用序列化?
1、内存中的对象需要写入硬盘 2、用套接字在网络上传输对象 3、RMI传输对象
序列化:
FileOutPutStream fout = new FileOutPutStream(".../.../文件名");// 也可以使用ByteArrayOutputStream
ObjectOutputStream out = new ObjectOutputStream(fout);
out.writeObject(要序列化的对象名);
out.close();
反序列化:
FileInputStrean fin = new FileInputStream(".../.../文件名");// 也可以使用ByteArrayInputStream
ObjectInputStream in = new ObjectInputStream(fin);
s = (Student)in.readObject();
in.close();
在反序列化是会检查当前对象与之前对象的SerialVersionUID是否一致,如果不一致则会抛出InvalidCastException(序列化版本不一致)的错误。
一般通过增加一个默认值得方法来避免兼容性错误:
private static final long SerialVersionUID = 1L;
注:对象中的transient、static 类型的变量不会写入。