文章目录
什么是序列化和反序列化
序列化:将Java对象转换为与平台无关的二进制流,从而允许把二进制流持久保存在磁盘上.
反序列化:通过网络将这种二进制流传输到另一个网络节点并恢复成原始状态.
为什么需要序列化机制
序列化使得对象可以脱离程序的运行而独立存在.这就意味着我们可以直接使用配置好的类对象而不在一步步从初始化开始配置,不仅减少了代码量,还能远程传输对象(这意味着这个对象能够从一台电脑传到另一台电脑中使用).
如何实现序列化
实现Serializable或Externalizable
举个实现Serializable接口的例子
已知Person类实现了Serializable接口.
- 创建一个对象输出流ObjectOutputStream绑定到某个可持久化对象中
ObjectOutputStream oos=new ObjectOutputStream(new FileOutputStream("保存序列化对象的文件.txt"));
- 调用ObjectOutputStream对象的WriteObject方法输出可序列化对象
Person per=new Person();
oos.Write(per);
举一个反序列化的例子
- 创建一个对象输入流ObjectInputStream,这个输入流是处理流,需要包装一个节点流
ObjectInputStream ois=new ObjectInputStream(new FileInputStream("保存序列化对象的文件.txt"));
- 调用对象输入流的readObject方法,这会返回一个object对象,如果你知道这个序列化对象原来的类型就可以强转.
Person p=(Person) ois.readObject();
反序列化需要注意的误区
反序列化读