版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/a_hui_tai_lang/article/details/79417338
源码中transient的用途
Java的serialization提供了一种持久化对象实例的机制。当持久化对象时,可能有一个特殊的对象数据成员,我们不想用serialization机制来保存它。为了在一个特定对象的一个域上关闭serialization,可以在这个域前加上关键字transient,transient是Java语言的关键字,用来表示一个域不是该对象串行化的一部分。当一个对象被串行化的时候,transient型变量的值不包括在串行化的表示中,然而非transient型的变量是被包括进去的。另外,静态变量也是无法序列化的。
那么,让我们看一下序列化的代码如下:
class LoggingInfo implements java.io.Serializable {
private Date loggingDate = new Date();
private String uid;
// private String pwd;
private transient String pwd;
LoggingInfo(String user, String password) {
uid = user;
pwd = password;
}
public String toString() {
String password=null;
if(pwd == null) {
password = "未设置密码";
}
else {
password = pwd;
}
return "logon info: \n " + "user: " + uid +
"\n logging date : " + loggingDate.toString() +
"\n password: " + password;
}
}
现在我们再创建一个这个类的实例,并且串行化(serialize)它 ,然后将这个串行化对象写如磁盘。
public class TransientTest {
public static void main(String[] args) {
LoggingInfo logInfo = new LoggingInfo("MIKE", "MECHANICS");
System.out.println(logInfo.toString());
try {
ObjectOutputStream o = new ObjectOutputStream(new FileOutputStream("logInfo.out"));
o.writeObject(logInfo);
o.close();
}
catch(Exception e) {
}
//To read the object back, we can write
try {
ObjectInputStream in =new ObjectInputStream(new FileInputStream("logInfo.out"));
LoggingInfo logInfo2 = (LoggingInfo)in.readObject();
System.out.println(logInfo2.toString());
}
catch(Exception e) {
}
}
}
运行这段代码,我们会注意到从磁盘中读回(read——back (de-serializing))的对象打印password为”未设置密码”,此时是我们定义pwd域为transient时,所期望的正确结果。
如果将pwd域前修饰符transient去掉,再做一次发现password内容会打印出传入的参数内容,即:MECHANICS,也符合我们所期望的结果。