大白话理解 Java 序列化:对标前端 JSON.stringify/parse

本文用极简示例对比前端 JSON 处理和 Java 对象序列化,零基础也能看懂,核心类比:Java 序列化 ≈ 前端 JSON.stringify ()Java 反序列化 ≈ 前端 JSON.parse ()

一、前端极简示例(JSON.stringify/JSON.parse)

核心逻辑:把「活对象」转成字符串存储,再从字符串还原成「活对象」

javascript 复制代码
// 1. 定义一个"活的"对象(有属性、可调用)
const user = {
    name: "张三",
    age: 25
};

// 2. 序列化:对象 → JSON字符串(对应Java的ObjectOutputStream)
// 把内存中的对象转成可存储/传输的字符串格式
const userStr = JSON.stringify(user); 
// 模拟存到本地(对应Java的FileOutputStream写文件)
localStorage.setItem("user", userStr);

// 3. 反序列化:JSON字符串 → 对象(对应Java的ObjectInputStream)
// 从本地读取字符串(对应Java的FileInputStream读文件)
const readStr = localStorage.getItem("user"); 
// 把字符串还原成可操作的对象
const newUser = JSON.parse(readStr);

// 验证结果
console.log("反序列化结果:", newUser); // 输出:{name: "张三", age: 25}

// 清理本地存储(可选)
localStorage.removeItem("user");

二、Java 极简示例(4 个核心类全包含)

核心逻辑:把 Java 对象转成字节存到文件,再从文件字节还原成 Java 对象涉及核心类:FileOutputStreamObjectOutputStream(序列化)、FileInputStreamObjectInputStream(反序列化)

步骤 1:定义可序列化的 User 类

java

运行

arduino 复制代码
import java.io.Serializable;

/**
 * 要序列化的类必须实现Serializable接口(标记接口,无实际方法)
 * 相当于给对象贴"可序列化标签"
 */
public class User implements Serializable {
    // 序列化版本号(固定写法,避免类结构变更导致反序列化失败)
    private static final long serialVersionUID = 1L;
    
    // 简单属性
    String name;
    int age;
    
    // 构造方法:初始化对象
    public User(String name, int age) {
        this.name = name;
        this.age = age;
    }
}

步骤 2:核心序列化 + 反序列化代码

java 复制代码
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.ObjectInputStream;
import java.io.ObjectOutputStream;

public class SimpleSerializeDemo {
    public static void main(String[] args) throws Exception {
        // ===================== 序列化(输出)=====================
        // 1. FileOutputStream:负责和文件交互,写字节到文件
        FileOutputStream fos = new FileOutputStream("user.txt");
        // 2. ObjectOutputStream:负责把Java对象转换成字节
        ObjectOutputStream oos = new ObjectOutputStream(fos);
        // 3. 核心操作:将"活对象"写入文件
        oos.writeObject(new User("张三", 25));
        oos.close(); // 关闭流(释放资源)

        // ===================== 反序列化(输入)=====================
        // 4. FileInputStream:负责和文件交互,从文件读字节
        FileInputStream fis = new FileInputStream("user.txt");
        // 5. ObjectInputStream:负责把字节还原成Java对象
        ObjectInputStream ois = new ObjectInputStream(fis);
        // 6. 核心操作:从文件读取并还原对象(强制类型转换)
        User newUser = (User) ois.readObject();
        ois.close(); // 关闭流(释放资源)

        // 验证结果
        System.out.println("反序列化结果:" + newUser.name + "," + newUser.age + "岁");
        // 输出:反序列化结果:张三,25岁
    }
}

三、核心对应关系

Java 操作 前端操作 大白话解释
FileOutputStream + ObjectOutputStream 写对象 JSON.stringify() 活对象 → 可存储的格式
FileInputStream + ObjectInputStream 读对象 JSON.parse() 可存储的格式 → 活对象

四、关键总结

  1. 核心逻辑一致:不管是 Java 还是前端,都是「活对象 ↔ 可存储格式」的互相转换;
  2. 类分工明确 :Java 中FileXxxStream管 "和文件读写",ObjectXxxStream管 "对象和字节互转";
  3. 核心差异:JSON 是通用明文格式(跨语言),Java 序列化是二进制格式(仅 Java 识别)。

本文示例极简可直接运行,新手也能快速理解 Java 序列化的核心逻辑~

相关推荐
天渺工作室6 小时前
实现一个adblock/adblock plus等浏览器广告拦截器检测插件
前端·javascript
阳光是sunny7 小时前
Vue 项目怎么做用户行为全链路监控?轻量插件方案详解
前端·面试·架构
ZhengEnCi7 小时前
Q04-Vite禁用CSS代码分割-解决生产环境样式加载顺序混乱问题
前端·vue.js·vite
九酒7 小时前
AI Agent 开发踩坑记:口播功能非得用 APP 原生实现吗?
前端·人工智能·agent
Jackson__8 小时前
做了一段时间的AI coding后,我终于搞清了 CLI 和 MCP 的区别
前端·agent·ai编程
IT_陈寒11 小时前
JavaScript项目实战经验分享
前端·人工智能·后端
用户479492835691511 小时前
6w star,GitHub 趋势第一的 Ponytail,这个agent插件到底在火什么
前端·后端
薛定喵的谔13 小时前
我开源了一个精致的 Next.js 博客模板:Skyplume
前端·前端框架·next.js
张龙68713 小时前
构建生产级 AI Agent:工具调用与记忆架构实战指南
前端
kyriewen14 小时前
2026 年了,还在用 Node.js?Bun 迁移实战:20 分钟搞定,附踩坑记录
前端·javascript·node.js