登录
首页 >  文章 >  java教程

Transient在Java序列化中的作用解析

时间:2026-04-29 16:43:41 421浏览 收藏

Java中的transient关键字是序列化机制中关键的“排除开关”,它精准控制哪些成员变量不参与对象的序列化与反序列化过程——仅对实现Serializable接口的类生效,跳过敏感数据(如密码、token)、临时状态(如缓存、连接句柄)或不可序列化字段,避免安全风险与运行异常;值得注意的是,static+transient纯属冗余,final transient字段反序列化后将按类型默认值(null/0/false)重置,而若需更精细控制,还可结合readObject自定义恢复逻辑。理解transient,是掌握Java持久化与网络传输安全的必修一课。

在Java中transient关键字有什么作用_transient在Java序列化中的意义解析

transient 关键字用于标记类的成员变量,使其在对象序列化时被跳过——不写入字节流,也不参与反序列化恢复。

它只对序列化起作用

只有当类实现了 Serializable 接口,并使用 ObjectOutputStream 进行序列化时,transient 才生效。它不影响普通赋值、方法调用或内存中的运行状态。

  • 未实现 Serializable 的类,即使加了 transient,也根本不会触发序列化逻辑
  • static 变量本身就不参与序列化,所以 static + transient 是冗余写法,JVM 忽略 transient
  • final 变量若被 transient 修饰,仍不序列化;但反序列化后会按 final 规则初始化(如 String 类型为 null,int 为 0)

典型适用场景

核心原则:该字段不该持久化、不该跨网络传输、或无法安全保存。

  • 敏感数据:密码、token、密钥等,避免明文落盘或被中间节点截获
  • 临时/派生状态:比如缓存计算结果、UI 组件引用、线程局部变量、数据库连接句柄等
  • 不可序列化类型:成员变量类型未实现 Serializable(如某些第三方类、InputStream),又不想改其源码时,用 transient 跳过可避免 NotSerializableException

反序列化后的值怎么处理

transient 字段在反序列化后不会保留原值,而是直接赋予对应类型的默认值:

  • 基本类型 → 0(int/long)、false(boolean)、\u0000(char)
  • 引用类型 → null
  • 数组 → null(不是空数组)

如果需要自定义反序列化行为(例如重置某个 transient 字段),可实现 readObject 方法,在其中手动赋值。

和 Externalizable 的区别

Serializable 是“默认全量序列化,用 transient 黑名单排除”;Externalizable 则是“默认不序列化任何字段,必须在 writeExternal/readExternal 中显式写出”。后者更灵活,但开发成本高,且容易遗漏字段导致兼容问题。

transient 在 Externalizable 中依然有效——如果你在 writeExternal 中没写某个 transient 字段,它自然不会出现;但如果你写了,JVM 不会阻止,因为 Externalizable 完全由你控制。

今天关于《Transient在Java序列化中的作用解析》的内容就介绍到这里了,是不是学起来一目了然!想要了解更多关于的内容请关注golang学习网公众号!

资料下载
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>