transient用于防止字段被序列化,如密码、临时数据或不可序列化对象,确保安全与兼容。

transient 是 Java 中的一个关键字,用来修饰类的成员变量。它的主要作用是:在对象序列化(Serialization)过程中,被 transient 修饰的变量不会被保存到文件或传输流中,也就是说,这个字段会被序列化机制忽略。
为什么需要 transient?
当一个对象实现 Serializable 接口后,Java 可以将其状态转换为字节流,便于存储或网络传输。但并不是所有字段都适合或需要被持久化。比如:
- 敏感信息(如密码),出于安全考虑不应被序列化
- 临时缓存数据,反序列化后可以重新生成
- 某些不能被序列化的对象(如线程、Socket连接等)
这时就可以用 transient 来排除这些字段。
使用示例
下面是一个简单的例子:
自从百度屏蔽淘宝客网站、淘宝抛弃淘宝客之后,个人站长集体陷入了恐慌之中。此时,什么值得买网的异军突起引起了广大个人站长的极大关注。做一个什么值得买一样的导购网站成了众多个人站长的一致心愿! TP-COUPON 导购系统 即是让个人站长实现此心愿的绝佳选择! 欢迎个人站长选用。V1.1版 更新记录:1.修正请求时查询淘宝店铺错误的bug2.删除一些无用的代码
立即学习“Java免费学习笔记(深入)”;
public class User implements Serializable {private String username;
private transient String password;
public User(String username, String password) {
this.username = username;
this.password = password;
}
@Override
public String toString() {
return "User{username='" + username + "', password='" + password + "'}";
}
}
当你序列化并反序列化这个对象时,username 会被正常恢复,而 password 会变成 null(因为被标记为 transient,未被保存)。
注意事项
- transient 只对序列化有效,不影响程序正常运行中的字段使用
- 静态变量本身就不会被序列化,所以加不加 transient 没区别
- 如果需要自定义某个 transient 字段的序列化逻辑,可以通过实现 writeObject 和 readObject 方法来控制
基本上就这些。transient 的用途很明确:在序列化时保护或排除特定字段,是一种简单有效的控制手段。










