当前位置: 首页 > news >正文

一文了解Java序列化和反序列化:对象的存储与传输

一文了解Java序列化和反序列化:对象的存储与传输

作者:Stevedash
发布时间:2023年8月9日 21点30分

前言

Java序列化是一项强大而重要的技术,它允许我们将对象转换为字节流,以便在存储、传输和重建时使用。在本文中,我们将深入探讨Java序列化的基本概念、使用方法以及一些应用场景。

在这里插入图片描述

基本概念:什么是Java序列化?

Java序列化是指将对象转换为字节流的过程,以便可以将其存储到文件、数据库或在网络上传输,并在需要时重新构建对象。序列化是Java的一个核心特性,它允许我们保存对象的状态并在需要时还原它们,从而实现持久化和数据交换。


如何进行Java序列化?

要进行Java序列化,首先需要确保被序列化的类实现了java.io.Serializable接口。这是一个标记接口,没有定义任何方法,只是用来标识该类可以进行序列化。接下来,我们可以使用ObjectOutputStream类将对象序列化为字节流,或使用ObjectInputStream类将字节流反序列化为对象。

下面是一个简单的示例:

import java.io.*;public class SerializationExample {public static void main(String[] args) {// 创建一个要序列化的对象Student student = new Student("Alice", 20, "CS");try {// 创建文件输出流,将对象序列化到文件FileOutputStream fileOut = new FileOutputStream("student.ser");ObjectOutputStream out = new ObjectOutputStream(fileOut);out.writeObject(student);  // 将对象写入输出流out.close();  // 关闭输出流fileOut.close();  // 关闭文件输出流System.out.println("对象已序列化");} catch (IOException e) {e.printStackTrace();}try {// 创建文件输入流,将文件中的字节流反序列化为对象FileInputStream fileIn = new FileInputStream("student.ser");ObjectInputStream in = new ObjectInputStream(fileIn);Student deserializedStudent = (Student) in.readObject();  // 从输入流中读取对象in.close();  // 关闭输入流fileIn.close();  // 关闭文件输入流System.out.println("对象已反序列化");System.out.println("姓名:" + deserializedStudent.getName());System.out.println("年龄:" + deserializedStudent.getAge());System.out.println("专业:" + deserializedStudent.getMajor());} catch (IOException | ClassNotFoundException e) {e.printStackTrace();}}
}class Student implements Serializable {private String name;  // 学生姓名private int age;  // 学生年龄private String major;  // 学生专业// 构造方法,初始化学生信息public Student(String name, int age, String major) {this.name = name;this.age = age;this.major = major;}// 省略 getter 和 setter 方法
}

在上述示例中,我们首先创建一个Student类并实现了Serializable接口。然后,我们将一个Student对象序列化到文件student.ser中,再从文件中反序列化出一个新的Student对象。


序列化的应用场景

Java序列化在很多场景中都有用武之地,包括但不限于以下几个方面:

  1. 对象的持久化存储: 序列化允许我们将对象保存在文件或数据库中,以便在程序重新运行时恢复对象的状态。

  2. 网络传输: 序列化可以将对象转换为字节流,便于在网络上进行传输,例如在客户端和服务器之间交换数据。

  3. 缓存: 序列化可以用于将对象存储在缓存中,以提高数据的访问速度。


Java序列化的优点和缺点

优点:

  • 持久化存储: Java序列化允许对象在存储时保持其状态,以便在程序重新启动后恢复。

  • 跨平台传输: 序列化可以将对象转换为字节流,在不同的平台之间传输,无需担心不同的数据格式问题。

  • 对象复制: 序列化可以用于创建对象的副本,无需手动复制每个属性。


缺点:

  • 性能开销: 序列化过程需要将对象转换为字节流,涉及到大量的IO操作,可能对性能产生一定影响。

  • 版本兼容性: 如果类的结构发生变化,反序列化可能会出现问题,需要特殊处理版本兼容性。


序列化的条件和注意事项

要进行Java序列化,需要注意以下条件和事项:

  • 被序列化的类必须实现java.io.Serializable接口。

  • 静态变量不会被序列化,因为它们属于类而不是对象。

  • 序列化并不保存类的方法,只保存对象的状态。

  • 被序列化的类中如果包含了对其他对象的引用,这些引用的对象也必须是可序列化的。

  • 在版本兼容性方面,当类的结构发生变化时,需要使用serialVersionUID来确保反序列化过程的正确性。


什么是反序列化?

反序列化是将字节流转换回对象的过程,即将序列化后的字节流重新构建为对象。通过反序列化,我们可以将之前序列化的对象重新还原成原来的状态,从而实现数据的恢复和重建。


序列化和反序列化的区别

序列化和反序列化是两个相互关联的过程,它们分别实现了对象的存储和重建。序列化将对象转换为字节流以便存储和传输,而反序列化则

将字节流重新还原为对象,从而实现数据的恢复。这两个过程在Java中都是重要且常用的操作,它们一起构成了对象持久化和数据交换的基础。


总结

Java序列化是一项强大的技术,允许我们将对象转换为字节流以进行存储、传输和重建。通过实现Serializable接口,并使用ObjectOutputStreamObjectInputStream,我们可以轻松地实现对象的序列化和反序列化。在适当的场景下,序列化可以提供持久化、数据交换和缓存等多种好处。但要注意条件和版本兼容性,以确保序列化和反序列化的正确性。

希望本文对你理解Java序列化提供了一些帮助。
作者:Stevedash

发表于:2023年8月9日21点30分

来源:Java 序列化 | 菜鸟教程 (runoob.com)

注:本文内容基于个人学习理解,如有错误或疏漏,欢迎指正。感谢阅读!如果觉得有帮助,请点赞和分享。

http://www.lryc.cn/news/117532.html

相关文章:

  • react-codemirror2 编辑器需点击一下或者延时才显示数据的问题
  • 火山引擎联合Forrester发布《中国云原生安全市场现状及趋势白皮书》,赋能企业构建云原生安全体系
  • 需要数电发票接口的,先熟悉下数电发票基本常识
  • node-sass是什么
  • C语言指针之 进阶
  • C++单例模式
  • C++ 析构函数
  • CSS——字体选择
  • SpringBoot自动装配及run方法原理探究
  • Mybatis实现JsonObject对象与JSON之间交互
  • spring boot 集成 jetcache【基础篇:@Cached、@CreateCache、@CacheRefresh】
  • 个人对前后端分离的一些看法
  • TailWindCss 在Hbuilderx中使用
  • Unity导入图片时,通过设置属性快速实现资源的压缩
  • AlmaLinux 9 安装 Go 1.20
  • 【Docker】数据库动态授权组件在Kubernetes集群下的测试过程记录
  • 数据结构【第3章】——线性表
  • MySql之分库分表
  • 数据结构—图的遍历
  • MySQL主从复制基于二进制日志的高可用架构指南
  • RestTemplate HTTPS请求忽略SSL证书
  • Jenkins触发器时间、次数设定
  • kafka partition的数据文件(offffset,MessageSize,data)
  • htnl根据轮播图图片切换背景色
  • gpu-manager安装及测试
  • Go和Java实现享元模式
  • Zookeeper特性与节点数据类型详解
  • 函数的递归
  • Android T 窗口层级其二 —— 层级结构树的构建(更新中)
  • ASIC芯片设计全流程项目实战课重磅上线 ,支持 65nm制程流片 !