java中的transient关键字

本文深入解析Java中的transient关键字,探讨其在序列化过程中的作用与底层实现原理,包括如何避免敏感信息的序列化,以及在实现Serializable和Externalizable接口时的不同表现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、了解transient关键字

  • 将不需要序列化的属性前添加关键字transient,序列化对象的时候,这个属性就不会被序列化。

实现Serializable接口的方式示例如下:
1)、创建一个序列化Emp类,如下图:
在这里插入图片描述
2)、在序列化SerializeEmp方法中将对象写入到文件中,然后反序列化DeserializeEmp
方法中读取文件中的数据。这就是序列化和反序列化的基本实现。如下图:
在这里插入图片描述3、由下图的输出结果可以看出,age属性变为了0,说明被transient关键字修饰之后没有被序列化。
在这里插入图片描述

二、深入分析transient关键字

1、transient底层实现原理是什么?

  • java的serialization提供了一个非常棒的存储对象状态的机制,说白了serialization就是把对象的状态存储到硬盘上 去,等需要的时候就可以再把它读出来使用。
  • 有些时候像银行卡号这些字段是不希望在网络上传输的,transient的作用就是把这个字段的生命周期仅存于调用者的内存中而不会写到磁盘里持久化,意思是transient修饰的age字段,他的生命周期仅仅在内存中,不会被写到磁盘中。

2、被transient关键字修饰过得变量真的不能被序列化嘛?

  • 想要解决这个问题,首先还要再重提一下对象的序列化方式。
  • Java序列化提供两种方式。一种是实现Serializable接口。另一种是实现Exteranlizable接口,需要重写writeExternal和readExternal方法。

实现Exteranlizable接口的方式示例如下:

1)、创建一个序列化Dept类,如下图:
在这里插入图片描述2)、在序列化SerializeDept方法中将对象写入到文件中,然后反序列化DeserializeDept
方法中读取文件中的数据。这就是序列化和反序列化的基本实现。如下图:
在这里插入图片描述3)、由下图的输出结果可以看出,实现了Externalizable接口,哪一个属性被序列化是我们手动去指定的,即使是transient关键字修饰也不起作用。
在这里插入图片描述3、静态变量能被序列化吗?没被transient关键字修饰之后呢?

  • 这个我可以提前先告诉结果,静态变量是不会被序列化的,即使没有transient关键字修饰。
    示例就不在演示了。。。

三、transient关键字总结

java 的transient关键字为我们提供了便利,你只需要实现Serilizable接口,将不需要序列化的属性前添加关键字transient,序列化对象的时候,这个属性就不会序列化到指定的目的地中。像银行卡、密码等等这些数据。这个需要根据业务情况了。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小志的博客

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值