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

序列化VS反序列化

序列化、反序列化定义

        如果我们需要持久化 Java 对象比如将 Java 对象保存在文件中,或者在网络传输 Java 对象,这些场景都需要用到序列化。

        序列化(Serialization)是指将对象转换为字节序列的过程,也可以称之为对象的持久化。在 Java 中,可以通过实现 Serializable 接口来实现对象的序列化。序列化后的字节序列可以保存到文件、数据库或网络中,以便在需要时进行读取和传输。

        反序列化(Deserialization)则是将字节序列转换为对象的过程,即恢复出原始的对象。在 Java 中,可以使用 ObjectInputStream 类来进行反序列化操作。反序列化的结果应该与原始对象完全一致,包括所有成员变量的值和对象的状态。

        Java 的序列化和反序列化机制是 Java 语言中非常重要的机制之一,它使得 Java 对象可以在不同的 JVM 和系统之间进行传递和共享。但是在实际应用中,需要注意一些序列化和反序列化的问题,如跨语言的兼容性、序列化版本控制、安全性等。

        在 C++这种半面向对象的语言中,struct(结构体)定义的是数据结构类型,而 class 对应的是对象类型。

序列化和反序列化应用场景

  • 对象在进行网络传输(比如远程方法调用 RPC 的时候)之前需要先被序列化,接收到序列化的对象之后需要再进行反序列化;
  • 将对象存储到文件之前需要进行序列化,将对象从文件中读取出来需要进行反序列化;
  • 将对象存储到数据库(如 Redis)之前需要用到序列化,将对象从缓存数据库中读取出来需要反序列化;
  • 将对象存储到内存之前需要进行序列化,从内存中读取出来之后需要进行反序列化。

序列化和反序列化代码实战

import java.io.*;public class SerializationDemo {public static void main(String[] args) {// 创建一个 Person 对象Person person = new Person("Alice", 20);// 对象序列化到文件中try (ObjectOutputStream out = new ObjectOutputStream(new FileOutputStream("person.txt"))) {out.writeObject(person);System.out.println("Person 对象已经序列化到 person.txt 文件中");} catch (IOException e) {e.printStackTrace();}// 从文件中读取对象并反序列化try (ObjectInputStream in = new ObjectInputStream(new FileInputStream("person.txt"))) {Person restoredPerson = (Person) in.readObject();System.out.println("从 person.txt 文件中反序列化出的 Person 对象:" + restoredPerson);} catch (IOException | ClassNotFoundException e) {e.printStackTrace();}}
}// 实现 Serializable 接口,使该类可以进行序列化
class Person implements Serializable {private String name;private int age;public Person(String name, int age) {this.name = name;this.age = age;}@Overridepublic String toString() {return "Person{name='" + name + "', age=" + age + "}";}
}

        在上述代码中,创建了一个 Person 对象,并将其序列化到 person.ser 文件中。接着从该文件中读取数据,并反序列化出一个新的 Person 对象。最后将这个新的 Person 对象输出到控制台。

        需要注意的是,如果要进行序列化和反序列化操作,需要保证被序列化的 Java 对象实现了 java.io.Serializable 接口。此外,还需要使用 ObjectOutputStream 和 ObjectInputStream 来完成序列化和反序列化操作。

更多消息资讯,请访问昂焱数据。

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

相关文章:

  • 新数智空间:阿里云边缘云持续保持中国公有云市场第一
  • 【开源】基于JAVA语言的陕西非物质文化遗产网站
  • C++(Qt)软件调试---静态分析工具clang-tidy(18)
  • 2401llvm,clang的重构引擎
  • 【C语言深度剖析——第四节(关键字4)】《C语言深度解剖》+蛋哥分析+个人理解
  • 鸿蒙开发系列教程(五)--ArkTS语言:组件开发
  • Java:正则表达式讲解加举例,简洁易懂
  • 2.机器学习-K最近邻(k-Nearest Neighbor,KNN)分类算法原理讲解
  • ​WordPress顶部管理工具栏怎么添加一二级自定义菜单?
  • Linux安装ossutil工具且在Jenkins中执行shell脚本下载文件
  • Docker命令---搜索镜像
  • docker使用http_proxy配置代理
  • 综述:自动驾驶中的 4D 毫米波雷达
  • 蓝桥杯:1.特殊日期(Java)
  • 服务异步通讯之 SpringAMQP【微服务】
  • LED闪烁
  • php array_diff 比较两个数组bug避坑 深入了解
  • c++中STL的vector简单实现
  • C# 更改Bitmap图像色彩模式
  • 5.2 基于深度学习和先验状态的实时指纹室内定位
  • AIGC时代高效阅读论文实操
  • 对网站进行打点(不要有主动扫描行为)
  • 502. IPO(贪心算法+优先队列/堆)
  • 设计模式篇---中介者模式
  • 双端Diff算法
  • react+antd,Table表头文字颜色设置
  • 2024年1月18日Arxiv最热NLP大模型论文:Large Language Models Are Neurosymbolic Reasoners
  • 服务限流实现方案
  • 【RTOS】快速体验FreeRTOS所有常用API(1)工程创建
  • Red Hat Enterprise Linux 8.9 安装图解