news 2026/4/25 2:30:05

序列化和反序列化

作者头像

张小明

前端开发工程师

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/23 10:45:21

轻松玩转Git:图文详解常用命令与操作

Git简介 git是一个开源的分布式版本控制系统,可以有效、高速地处理从很小到很大的项目版本管理。 特点: 速度快简单的设计对非线性开发模式的强力支持(允许成千上万个并行开发的分支)完全分布式有能力高效管理类似Linux内核一样超…

作者头像 李华
网站建设 2026/4/24 0:30:46

使用三方库头文件未使用导出符号情景

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录核心结论先行一、关于省略 __declspec 修饰符的原理与影响1. 为什么不用写也能正常导出?2. 使用方不写 __declspec(dllimport) 的影响二、关于省略 exter…

作者头像 李华
网站建设 2026/4/24 0:43:48

GPU服务器:驱动人工智能与科学计算的关键基础设施

在当下计算密集型任务愈发常见的情形里,图形处理单元服务器从一个专业范畴的概念,渐渐变成推动人工智能、科学计算以及视觉处理等前沿技术进步的关键基础设施。和传统中央处理器服务器主要借助少量复杂计算核心处理通用任务不一样,GPU服务器的…

作者头像 李华
网站建设 2026/4/24 2:43:51

主流门店管理软件对比,为商家提供选型思路

现今,实体商业正加速数字化转型,一套高效且适配的门店管理软件,已然成为零售、餐饮等服务行业用以提升运营效率、优化顾客体验以及实现业绩增长的核心工具。面对市场上种类繁多的产品,商家常常觉得难以进行抉择。本文的目的在于&a…

作者头像 李华
网站建设 2026/4/24 13:28:04

华为激活组织的“五大引擎”与“四驾马车”

在瞬息万变的商业环境中,企业最大的危机往往不是来自外部,而是内部的僵化与活力丧失。如何打破大企业病?如何让听得见炮声的人呼唤炮火?本文结合华为资深专家吕远洋的分享,为你揭秘激活组织活力的BRAVE模型与管理增效的…

作者头像 李华