java有个特点就是序列化(Serializable,简单地来说就是可以将这个类存储在物理空间(当然还是以文件的形式存在),这一操作又称为对象持久化保存
,那么当你从本地还原这个文件时,你可以将它转换为它本身。这可以极大地方便网络上的一些操作,但因为涉及到安全问题,所以并不希望把类里面所有的东西都进行存储(因为那样,别人可以通过序列化知道类里面的内容)
,这时我们就可以使用transient这个关键字,它的意思是临时的,即加上它之后的变量不会随类一起序列化到本地,所以当还原后,这个关键字定义的变量也就不再存在,这样就可以防止别人通过序列化知道类里面的内容。
接下来,简单的写一个demo
执行结果如下:
Sat Sep 09 16:52:44 CST 2017
user1
admin123
Sat Sep 09 16:52:44 CST 2017
user1
Not Set
如果我们在构造函数中给密码初始值,那么在将序列化之后的对象转换为具体类的对象时密码的值还存在吗?答案是否定的。将持久化对象转换为具体类的对象,并不会调用具体类的构造函数。
所以程序执行的结果仍然是Not Set