transient关键字用于控制Java对象字段的序列化行为,被声明为transient的字段在序列化时会被忽略,反序列化后其值为默认值。主要用于防止敏感数据(如密码)被持久化、优化序列化性能(如跳过可重建的缓存字段)、处理未实现Serializable接口的对象引用。与static字段不同,transient作用于实例字段,而static字段本身不参与序列化。反序列化后transient字段为空,必要时可通过readObject()方法恢复。

transient 关键字在 Java 序列化中用于控制对象字段是否参与序列化过程。当一个字段被声明为 transient,它将在对象序列化时被忽略,不会被保存到字节流中,反序列化后该字段的值为默认值(如 null、0、false 等)。
防止敏感数据被序列化
某些字段包含敏感信息或临时状态,不应当被持久化。例如密码、会话标识或缓存数据。
比如:- 用户对象中的密码字段应避免写入文件或网络传输
- 某个计算结果缓存只在运行时有效,无需保存
使用 transient 可以确保这些字段不会随对象一起被序列化。
优化序列化性能和体积
大型或可重建的字段如果参与序列化,会增加数据大小并降低效率。
立即学习“Java免费学习笔记(深入)”;
例如:- 一个集合字段可以从数据库重新加载
- 图像处理中的中间缓冲区不需要保留
将这类字段标记为 transient 能减小序列化后的数据量,提升性能。
处理无法序列化的对象引用
如果某个字段的类型没有实现 Serializable 接口,直接序列化会导致 NotSerializableException。
- 将其声明为 transient 可跳过该字段,避免异常
- 后续可通过其他方式恢复其状态(如初始化或重新获取)
这是一种简单有效的兼容性处理手段。
与 static 字段的区别
transient 仅对实例字段有意义。static 字段本身不属于对象状态,不会被序列化,因此无需用 transient 修饰。但若 static 字段被错误地认为需要保护,加上 transient 也不会报错,只是无实际作用。
基本上就这些。transient 是一个轻量且实用的控制工具,在需要排除特定字段时非常方便。注意反序列化后 transient 字段为空,必要时可通过 readObject() 方法手动恢复。









