0

0

Java中的序列化与反序列化_Serializable接口与transient关键字的应用

P粉602998670

P粉602998670

发布时间:2026-02-11 12:20:42

|

203人浏览过

|

来源于php中文网

原创

transient 字段反序列化时为 null 是因 JVM 跳过其序列化,属设计行为;未声明 serialVersionUID 会导致类结构变更后反序列化失败;推荐手动设为 1L 并谨慎升级;JSON、protobuf 等是更安全可靠的替代方案。

java中的序列化与反序列化_serializable接口与transient关键字的应用

为什么反序列化时 transient 字段总是 null

因为 transient 的语义就是“不参与序列化”,JVM 在写入字节流时直接跳过它,反序列化自然无法恢复。这不是 bug,是设计行为。

  • 仅对实例变量生效,static 字段本就不序列化,加 transient 无意义
  • 若字段类型本身不可序列化(如 ThreadSocket),必须加 transient,否则抛 NotSerializableException
  • 想在反序列化后自动初始化该字段?重写 readObject 方法,在里面赋值,别指望 JVM 自动填

serialVersionUID 不写会怎样

不显式声明 serialVersionUID,JVM 会按类结构自动生成一个;但只要类稍有改动(比如加个字段、改个访问修饰符),生成的值就变,导致反序列化失败:抛 InvalidClassException,提示 “local class incompatible”。

  • 线上服务升级时,老数据文件或缓存对象很可能因 serialVersionUID 不匹配而无法加载
  • 建议始终用 private static final long serialVersionUID = 1L; 起手,后续兼容性变更(如新增 transient 字段)不改它;破坏性变更再升版本号
  • IDE(如 IntelliJ)可自动生成基于当前类结构的哈希值,但不如手动设为 1L 来得可控

自定义序列化逻辑:什么时候必须重写 writeObjectreadObject

当默认机制无法满足需求时才动手——比如字段加密、敏感信息过滤、父类字段补全、或兼容旧版本数据格式。

  • 这两个方法必须是 private void writeObject(ObjectOutputStream out)private void readObject(ObjectInputStream in),签名错一个字符就无效
  • 务必在第一行调用 defaultWriteObject()defaultReadObject(),否则非 transient 字段全丢
  • 如果类继承自不可序列化的父类,且父类有状态字段,必须在 readObject 中手动重建父类状态(通过反射或构造器)

替代 Serializable 的更可靠方案有哪些

Java 原生序列化脆弱、慢、不跨语言、有安全风险(反序列化 gadget 攻击),生产环境应优先考虑替代方案。

Interior AI
Interior AI

AI室内设计,上传室内照片自动帮你生成多种风格的室内设计图

下载

立即学习Java免费学习笔记(深入)”;

  • JSON(用 jacksonGson):人眼可读、跨语言、字段增删兼容性好,但丢失类型信息和 final 字段语义
  • Protocol Buffersprotobuf):体积小、速度快、强契约,需预定义 .proto 文件,适合微服务间通信
  • 完全避免序列化:用数据库主键代替对象直传,或用 DTO + 显式构造,把“序列化”这个隐式过程变成可测试、可审计的显式转换

真正麻烦的从来不是怎么序列化,而是怎么让旧数据在新代码里活下来——这点上,任何二进制序列化都比不上带版本字段的 JSON。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

436

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

543

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

317

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

81

2025.09.10

c语言中null和NULL的区别
c语言中null和NULL的区别

c语言中null和NULL的区别是:null是C语言中的一个宏定义,通常用来表示一个空指针,可以用于初始化指针变量,或者在条件语句中判断指针是否为空;NULL是C语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

243

2023.09.22

java中null的用法
java中null的用法

在Java中,null表示一个引用类型的变量不指向任何对象。可以将null赋值给任何引用类型的变量,包括类、接口、数组、字符串等。想了解更多null的相关内容,可以阅读本专题下面的文章。

685

2024.03.01

c语言中null和NULL的区别
c语言中null和NULL的区别

c语言中null和NULL的区别是:null是C语言中的一个宏定义,通常用来表示一个空指针,可以用于初始化指针变量,或者在条件语句中判断指针是否为空;NULL是C语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

243

2023.09.22

java中null的用法
java中null的用法

在Java中,null表示一个引用类型的变量不指向任何对象。可以将null赋值给任何引用类型的变量,包括类、接口、数组、字符串等。想了解更多null的相关内容,可以阅读本专题下面的文章。

685

2024.03.01

2026春节习俗大全
2026春节习俗大全

本专题整合了2026春节习俗大全,阅读专题下面的文章了解更多详细内容。

68

2026.02.11

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 3.5万人学习

C# 教程
C# 教程

共94课时 | 9.2万人学习

Java 教程
Java 教程

共578课时 | 63.4万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号