登录
首页 >  文章 >  java教程

Java对象流序列化与反序列化详解

时间:2025-07-09 18:16:43 385浏览 收藏

知识点掌握了,还需要不断练习才能熟练运用。下面golang学习网给大家带来一个文章开发实战,手把手教大家学习《Java中的对象流(ObjectInputStream和ObjectOutputStream)用于实现对象的序列化与反序列化。通过将对象转换为字节流,可以将其写入文件或通过网络传输,之后再读取还原为对象。使用方法如下:对象写入(序列化):创建ObjectOutputStream对象,包装一个输出流(如FileOutputStream)。调用writeObject()方法将对象写入流中。对象读取(反序列化):创建ObjectInputStream对象,包装一个输入流(如FileInputStream)。调用readObject()方法从流中读取对象。注意:对象必须实现Serializable接口才能被序列化。》,在实现功能的过程中也带大家重新温习相关知识点,温故而知新,回头看看说不定又有不一样的感悟!

对象流是Java中用于处理对象序列化与反序列化的工具,主要包括ObjectOutputStream和ObjectInputStream。1. ObjectOutputStream通过writeObject()方法将实现Serializable接口的对象写入流,2. ObjectInputStream通过readObject()方法从流中读取并还原对象。使用时需注意:对象必须实现Serializable接口;包含的其他自定义对象也必须可序列化;静态和transient字段不会被序列化;类结构变化可能导致反序列化失败,可通过serialVersionUID增强兼容性;多次写入同一对象仅保存一次引用。操作完成后应正确关闭流以避免资源泄露。

简述Java中的对象流(ObjectInputStream和ObjectOutputStream),如何使用它们进行对象的读写?

在Java中,对象流(ObjectInputStream 和 ObjectOutputStream)是用来处理对象序列化和反序列化的工具。简单来说,它们能将对象转换成字节流保存到文件或通过网络传输,也可以反过来从字节流还原出对象。

简述Java中的对象流(ObjectInputStream和ObjectOutputStream),如何使用它们进行对象的读写?

什么是对象流?

对象流是 Java IO 包中的两个类:

  • ObjectOutputStream:用于将对象写入输出流,也就是序列化。
  • ObjectInputStream:用于从输入流读取对象,也就是反序列化。

这两个类通常配合使用,常见于需要持久化保存对象状态、在网络上传输对象的场景。

简述Java中的对象流(ObjectInputStream和ObjectOutputStream),如何使用它们进行对象的读写?

要使用对象流,对象必须实现 Serializable 接口,这是一个标记接口,不包含任何方法,只是告诉 JVM 这个类可以被序列化。


如何用 ObjectOutputStream 写入对象?

写入对象的关键在于创建一个 ObjectOutputStream 实例,并调用其 writeObject() 方法。

简述Java中的对象流(ObjectInputStream和ObjectOutputStream),如何使用它们进行对象的读写?

基本步骤如下:

  • 创建一个实现了 Serializable 的类实例。
  • 使用 FileOutputStream 打开一个文件输出流。
  • 将其包装为 ObjectOutputStream
  • 调用 writeObject() 方法写入对象。
  • 最后关闭流。

示例代码片段:

try (ObjectOutputStream oos = new ObjectOutputStream(new FileOutputStream("person.dat"))) {
    Person person = new Person("张三", 25);
    oos.writeObject(person);
} catch (IOException e) {
    e.printStackTrace();
}

注意:

  • 流操作容易抛出异常,建议用 try-with-resources 自动关闭。
  • 如果写入多个对象,读取时也要按顺序一一对应。

如何用 ObjectInputStream 读取对象?

读取对象的过程是写入的逆过程。你需要创建一个 ObjectInputStream 并调用 readObject() 方法。

步骤大致如下:

  • 使用 FileInputStream 打开之前保存的对象文件。
  • 包装成 ObjectInputStream
  • 调用 readObject() 方法读取对象。
  • 强制类型转换为你期望的类型。
  • 关闭流。

示例代码:

try (ObjectInputStream ois = new ObjectInputStream(new FileInputStream("person.dat"))) {
    Person person = (Person) ois.readObject();
    System.out.println(person.getName());
} catch (IOException | ClassNotFoundException e) {
    e.printStackTrace();
}

这里需要注意:

  • readObject() 返回的是 Object 类型,必须进行类型转换。
  • 如果文件中有多个对象,可以循环调用 readObject() 直到读完。

序列化的一些细节

有些地方容易忽略但很重要:

  • 对象中如果包含其他自定义对象,这些对象也必须实现 Serializable,否则会抛出异常。
  • 静态字段和 transient 修饰的字段不会被序列化。
  • 如果类结构发生变化(比如增减字段),可能会导致反序列化失败。可以通过定义 serialVersionUID 来控制版本兼容性。
  • 多次写入同一个对象时,默认只会保存一次引用,后续写入的是引用标识,不会重复序列化整个对象。

基本上就这些。对象流虽然功能强大,但在使用时要注意类的设计和流的正确关闭,避免出现数据不一致或资源泄露的问题。

到这里,我们也就讲完了《Java对象流序列化与反序列化详解》的内容了。个人认为,基础知识的学习和巩固,是为了更好的将其运用到项目中,欢迎关注golang学习网公众号,带你了解更多关于反序列化,序列化,对象流,ObjectInputStream,ObjectOutputStream的知识点!

相关阅读
更多>
最新阅读
更多>
课程推荐
更多>