序列化反序列化为何要实现Serializable接口
概念
- 序列化:把对象转换成字节序列的过程
- 反序列化:把字节序列恢复为对象的过程
使用情况
只在本地jvm里面运行程序时,是不需要序列化与反序列化的,当我们需要将内存中的对象持久化到磁盘,数据库中,或者与数据库进行交互时,就需要序列化与反序列化了。
结论:在对内存中的对象进行持久化或网络传输时,需要用到序列化或反序列化。
服务器与浏览器交互的过程中,json格式实际上就是将一个对象转化成字符串,String类型实现了Serizaliable接口,并且指定了seialVersionUID的值。
public final class String
implements java.io.Serializable, Comparable<String>, CharSequence {
/** The value is used for character storage. */
private final char value[];
/** Cache the hash code for the string */
private int hash; // Default to 0
/** use serialVersionUID from JDK 1.0.2 for interoperability */
private static final long serialVersionUID = -6849794470754667710L;
}
实现Serizaliable接口后,jvm会在底层帮我们实现序列化和反序列化。
为何要指定serialVersionUID的值
如果不指定显示serialVersionUID的值,jvm在序列化时会自动生成一个serialVersionUID,跟属性一起序列化,再进行持久化或者网络传输,在反序列化时,jvm会根据属性自动生成一个新版的serialVersionUID,与旧的serialVersionUID进行比较,相同则反序列化成功。
特性
被transient关键字修饰的属性不会被序列化, static属性也不会被序列化。
因为序列化是针对对象的,static属性是优于对象的存在,随着类加载而加载,不会被序列化。
serialVersionUID属性并没有被序列化, JVM在序列化对象时会自动生成一个serialVersionUID, 然后将我们显示指定的serialVersionUID属性值赋给自动生成的serialVersionUID。