news 2026/4/22 21:38:28

序列化和反序列化

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
序列化和反序列化

一、核心概念(用生活例子理解)

想象一下:

  • 你有一个乐高拼好的小汽车(对应程序中的Java 对象,比如ChatMessage)。
  • 序列化:把这个乐高小汽车拆成一个个独立的零件,并用清单记录每个零件的位置、形状(→ 把 Java 对象转换成字节流 / JSON 字符串等可存储 / 传输的格式)。
  • 反序列化:根据清单,把零散的乐高零件重新拼成原来的小汽车(→ 把字节流 / JSON 字符串还原成原来的 Java 对象)。
官方定义

表格

操作核心含义
序列化 (Serialize)内存中的对象(如ChatMessage实例)转换为字节序列 / 字符串(如 JSON),方便存储到文件 / 数据库、或网络传输。
反序列化 (Deserialize)存储 / 传输的字节序列 / 字符串(如数据库里的 JSON)还原为内存中的对象,让程序可以直接使用。

二、为什么需要序列化 / 反序列化?

以你之前的代码场景为例:

  1. 存储需求ChatMessage对象是内存中的临时数据,程序重启就会消失。把它序列化成 JSON 字符串存到 MongoDB,就能持久化保存。
  2. 传输需求:如果你的聊天程序是分布式的(比如前端→后端→数据库),对象无法直接在网络中传输,需要序列化成 JSON / 二进制流,传输后再反序列化。
  3. 跨语言交互:JSON 是通用格式,Java 序列化的 JSON 字符串,前端 JavaScript 可以反序列化使用,实现跨语言数据交互。

三、代码示例(直观理解)

以你熟悉的ChatMessage为例,用 Jackson 库演示序列化 / 反序列化:

1. 准备实体类

java

运行

import com.fasterxml.jackson.databind.ObjectMapper; import lombok.Data; @Data // 简化getter/setter,需要lombok依赖 public class ChatMessage { private String memoryId; private String content; private Long timestamp; }
2. 序列化(对象 → JSON 字符串)

java

运行

public class SerializeDemo { public static void main(String[] args) throws Exception { // 1. 创建内存中的对象 ChatMessage message = new ChatMessage(); message.setMemoryId("mem_123"); message.setContent("你好,MongoDB!"); message.setTimestamp(System.currentTimeMillis()); // 2. 序列化:对象 → JSON字符串(相当于拆乐高) ObjectMapper objectMapper = new ObjectMapper(); String jsonStr = objectMapper.writeValueAsString(message); System.out.println("序列化后的JSON:"); System.out.println(jsonStr); // 输出:{"memoryId":"mem_123","content":"你好,MongoDB!","timestamp":1740000000000} } }
3. 反序列化(JSON 字符串 → 对象)

java

运行

public class DeserializeDemo { public static void main(String[] args) throws Exception { // 1. 从数据库/文件中读取的JSON字符串 String jsonStr = "{\"memoryId\":\"mem_123\",\"content\":\"你好,MongoDB!\",\"timestamp\":1740000000000}"; // 2. 反序列化:JSON字符串 → 对象(相当于拼乐高) ObjectMapper objectMapper = new ObjectMapper(); ChatMessage message = objectMapper.readValue(jsonStr, ChatMessage.class); System.out.println("反序列化后的对象:"); System.out.println("memoryId: " + message.getMemoryId()); // 输出:mem_123 System.out.println("content: " + message.getContent()); // 输出:你好,MongoDB! } }

四、常见的序列化格式

  1. JSON:最常用,可读性高、跨语言,你的代码中就是用这种格式(chatMessages.getContent()是 JSON 字符串)。
  2. XML:老牌格式,可读性高但体积大,现在用得少。
  3. 二进制序列化(Java 原生):把对象转成字节流,体积小但只能 Java 之间使用,不跨语言。
  4. Protobuf:谷歌出品,二进制格式,体积小、效率高,适合高性能传输场景。

总结

  1. 序列化:对象 → 字符串 / 字节流(便于存储 / 传输),核心是 “拆”。
  2. 反序列化:字符串 / 字节流 → 对象(便于程序使用),核心是 “拼”。
  3. 你代码中的messagesFromJson()就是典型的反序列化操作,把 MongoDB 中存储的 JSON 字符串还原成ChatMessage对象。
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/21 12:39:20

‌赛事数据测试:实时比分系统准确性验证

实时比分系统作为体育类应用、直播平台、博彩系统及数据服务的核心组件,其准确性直接关系到用户体验、商业信任与法律合规。对软件测试从业者而言,验证此类系统的数据一致性、时序正确性与高并发稳定性,是极具挑战性的质量保障任务。本文将从…

作者头像 李华
网站建设 2026/4/22 19:44:09

Java并发编程进阶:线程池原理、参数配置与死锁避免实战

在当今高并发的互联网时代,Java并发编程已成为构建高性能、高可靠性企业级应用的核心技术。根据Oracle发布的《2024年Java技术趋势报告》,全球超过85%的企业级应用采用Java开发,其中并发处理能力直接决定了系统的吞吐量和响应性能。特别是随着…

作者头像 李华
网站建设 2026/4/18 5:44:49

AI元人文:悟空悖论与悬鉴而行

AI元人文:悟空悖论——悬鉴而行 摘要 本文系统阐释岐金兰“AI元人文”理论中的核心命题——“悟空悖论”,并提出“悬鉴而行”的实践方法论。论文首先揭示算法时代人类认知面临的三重困境:欲望(Desire)被精准预测而固化…

作者头像 李华
网站建设 2026/4/21 16:17:59

API集成平台:构建企业数字化连接的核心引擎

当着前企业数字化转型的浪潮来临之际,数据跟应用的高效连通已然变成提升运营效率以及驱动业务创新的关键所在。传统的点对点的系统集成方式,常常致使接口重复去开发,耦合度高,运维艰难,从而形成难以打破的数据孤岛。AP…

作者头像 李华
网站建设 2026/4/19 15:05:01

【毕业设计】java-springboot+vue“智慧食堂”设计与实现

💟博主:程序员陈辰:CSDN作者、博客专家、全栈领域优质创作者 💟专注于计算机毕业设计,大数据、深度学习、Java、小程序、python、安卓等技术领域 📲文章末尾获取源码数据库 🌈还有大家在毕设选题…

作者头像 李华
网站建设 2026/4/17 20:45:59

奇点之后:Omega+级量子AI的世界

版权声明:本文为DREAMVFIA UNION原创作品,2026年版权所有。未经授权,禁止转载、摘编或以任何形式传播本文内容。 摘要 当人类文明的技术发展曲线趋向无穷大时,我们正站在一个前所未有的历史转折点。技术奇点——那个理论物理学家约翰冯诺依曼首次预言、人工智能先驱维诺尔…

作者头像 李华