为何要指定serialVersionUID的值
如果不指定显示serialVersionUID的值,jvm在序列化时会自动生成一个serialVersionUID,跟属性一起序列化,再进行持久化或者网络传输,在反序列化时,jvm会根据属性自动生成一个新版的serialVersionUID,与旧的serialVersionUID进行比较,相同则反序列化成功。
特性
被transient关键字修饰的属性不会被序列化, static属性也不会被序列化。
因为序列化是针对对象的,static属性是优于对象的存在,随着类加载而加载,不会被序列化。
serialVersionUID属性并没有被序列化, JVM在序列化对象时会自动生成一个serialVersionUID,
然后将我们显示指定的serialVersionUID属性值赋给自动生成的serialVersionUID。
transient关键字修饰的属性不会被序列化
Java中的transient关键字,transient是短暂的意思。对于transient 修饰的成员变量,在类的实例对象的序列化处理过程中会被忽略。
因此,transient变量不会贯穿对象的序列化和反序列化,生命周期仅存于调用者的内存中而不会写到磁盘里进行持久化。
在持久化对象时,对于一些特殊的数据成员(如用户的密码,银行卡号等),我们不想用序列化机制来保存它。为了在一个特定对象的一个成员变量上关闭序列化,可以在这个成员变量前加上关键字transient。
用来表示一个成员变量不是该对象序列化的一部分。当一个对象被序列化的时候,transient型变量的值不包括在序列化的结果中。而非transient型的变量是被包括进去的。
注意static修饰的静态变量天然就是不可序列化的。
transient关键字可以修饰局部变量吗? 不能!
transient关键字只能修饰变量,而不能修饰方法和类。注意,局部变量是不能被transient关键字修饰的,我想因为这些局部变量需要在被序列化的时候引用到,如果这写局部变量被
transient修饰,变量值不被序列化,反序列化后局部变量的值就变成默认值了,此时反序列化就没有意义了。
Java中的变量
*
成员变量(实例变量,属性)
*
局部变量(本地变量)
*
类变量(静态属性)