乐闻世界logo
搜索文章和话题

Java 中序列化和反序列化有什么区别?

5 个月前提问
5 个月前修改
浏览次数16

1个答案

1

Java中序列化和反序列化是相对应的两个过程,主要用于将对象的状态转换为可以存储或传输的格式,并能够在之后重建对象。

序列化 是指将对象的状态信息转换为可以保存到文件、存储在数据库中,或者通过网络传输的数据格式的过程。在Java中,这通常是通过实现 java.io.Serializable 接口来完成的。序列化后的格式可以是二进制流,也可以是XML、JSON等文本格式。

例如,假设我们有一个 Employee 类的对象,我们想将其状态保存到文件中,以便将来使用。我们可以通过以下方式序列化该对象:

java
Employee employee = new Employee("John", "Developer", 30); FileOutputStream fileOut = new FileOutputStream("employee.ser"); ObjectOutputStream out = new ObjectOutputStream(fileOut); out.writeObject(employee); out.close(); fileOut.close();

这段代码创建了一个 Employee 对象,并通过 ObjectOutputStream 类将其序列化到名为 employee.ser 的文件中。

反序列化 是序列化的逆过程,它将先前序列化的数据转换回原始的对象形态。这通常是通过读取序列化后的数据,并将其转换回原来的对象状态来实现的。

继续上面的例子,如果我们想从文件中恢复 Employee 对象的状态,我们可以通过以下方式进行反序列化:

java
FileInputStream fileIn = new FileInputStream("employee.ser"); ObjectInputStream in = new ObjectInputStream(fileIn); Employee e = (Employee) in.readObject(); in.close(); fileIn.close();

这段代码从文件 employee.ser 中读取序列化的数据,然后通过 ObjectInputStream 将其转换回 Employee 类的对象。

总的来说,序列化和反序列化是两个互补的过程,序列化用于对象的存储和传输,而反序列化用于恢复对象的状态。它们在分布式计算、持久化存储、深复制等场景中非常有用。

2024年8月7日 21:57 回复

你的答案