Java关键字——transient

“transient”——“瞬态”,先不说这个翻译是否恰当,这个变量关键字一直不曾使用,简单的说就是被瞬态定义的变量不可序列号。或者这么给他换个名字——“不可序列化状态”?
打个比方,如果一个用户有一些敏感信息(譬如密码,银行卡号等),为了安全起见,不希望在网络操作(主要涉及到序列化操作,本地序列化缓存也适用)中被传输。这些信息对应的变量就可以被定义为transient类型。换句话说,这个字段的生命周期仅存于调用者的内存中。
定义People
Java代码 收藏代码
  1. publicclassPeopleimplementsSerializable{
  2. privatestaticfinallongserialVersionUID=8294180014912103005L;
  3. /**
  4. *用户名
  5. */
  6. privateStringusername;
  7. /**
  8. *密码
  9. */
  10. privatetransientStringpassword;
  11. }


密码字段为transient,这时候如果对该对象进行序列化,这个密码字段是不会被保存的。
为了代码简洁,未将流操作至于try-catch中,仅为演示,勿仿!
Java代码 收藏代码
  1. publicstaticvoidmain(String[]args)throwsException{
  2. Peoplep=newPeople();
  3. p.setUsername("snowolf");
  4. p.setPassword("123456");
  5. System.err.println("------操作前------");
  6. System.err.println("username:"+p.getUsername());
  7. System.err.println("password:"+p.getPassword());
  8. ObjectOutputStreamoos=newObjectOutputStream(newFileOutputStream(
  9. "people.txt"));
  10. oos.writeObject(p);
  11. oos.flush();
  12. oos.close();
  13. ObjectInputStreamois=newObjectInputStream(newFileInputStream(
  14. "people.txt"));
  15. p=(People)ois.readObject();
  16. ois.close();
  17. System.err.println("------操作后------");
  18. System.err.println("username:"+p.getUsername());
  19. System.err.println("password:"+p.getPassword());
  20. }

执行操作:
引用
------操作前------
username: snowolf
password: 123456
------操作后------
username: snowolf
password: null

密码字段为null,反序列化时根本没有从文件中获取到信息。
适用场景:
1.不打算序列化某字段的值,节省空间
2.传递序列化流的时候,不传递该值等
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值