transient关键字用于指定字段不被序列化,如敏感信息、临时数据或线程资源,防止其写入持久化介质;反序列化时这些字段恢复为默认值。例如User类中password和loginCount声明为transient后不会被自动序列化,但可通过重写writeObject和readObject方法实现加密存储与恢复,从而在安全性和灵活性间取得平衡。

Java 中 transient 关键字用于控制对象序列化过程,它的主要作用是指定某些字段不被序列化。当一个字段被声明为 transient,在对象序列化到字节流时,该字段的值不会被保存;反序列化时,该字段将恢复为默认值(如 int 为 0,引用类型为 null)。
有些字段不适合或不需要持久化,比如:
NotSerializableException
class User implements Serializable {
private String username;
private transient String password; // 不会被序列化
private transient int loginCount = 0; // 临时统计信息
// 构造方法、getter/setter 省略
}
在这个例子中,即使 password 和 loginCount 有值,在序列化后它们的数据会丢失。反序列化得到的 User 对象中,这两个字段分别为 null 和 0。
如果某些 transient 字段需要特殊处理(比如加密存储),可以手动控制序列化逻辑:
立即学习“Java免费学习笔记(深入)”;
private void writeObject(ObjectOutputStream out) throws IOException {
out.defaultWriteObject(); // 先序列化非 transient 字段
out.writeUTF(encrypt(password)); // 手动写出加密后的密码
}
private void readObject(ObjectInputStream in) throws IOException, ClassNotFoundException {
in.defaultReadObject(); // 恢复非 transient 字段
password = decrypt(in.readUTF()); // 手动读取并解密
}
这种方式可以在保证安全的同时,实现部分 transient 字段的自定义持久化。
基本上就这些。transient 是一个简单但实用的机制,帮助开发者精细控制序列化行为,避免不必要的数据暴露或错误。
以上就是Java transient关键字在序列化中的作用是什么的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号