序列化和反序列化

Posted 皇甫哲

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了序列化和反序列化相关的知识,希望对你有一定的参考价值。

什么是java的序列化和反序列化

java序列化就是把java对象转换为字节序列的过程。对于transient和static修饰的属性不会被序列化。原因:transient的作用就是这样,static是因为序列化作用的是对象,static修饰后是属于类的,所以没用。

java反序列化就是把字节序列转换为java对象的过程。

 

为什么要序列化

很多应用中,需要对对象进行序列化,让它们离开内存,放入到硬盘中去,以便长期保存。比如session,当有10万用户并发访问,可能出现10万个session对象,内存可能吃不消,web容器会把一些session序列化到硬盘中,

需要用的时候,再还原回来。

 

序列化需要实现java.io.Serializable接口,序列化的时候有一个serialVersionUID参数,java序列化机制是通过运行时判断类的serialVersionUID来验证版本一致性。在进行反序列化,Java虚拟机会把传过来的字节流中的serialVersionUID和本地相应实体类的serialVersionUID进行比较,如果相同就认为是一致的实体类,可以进行反序列化,否则Java虚拟机会拒绝对这个实体类进行反序列化并抛出异常。serialVersionUID有两种生成方式:

 

1、默认的1L

 

2、根据类名、接口名、成员方法以及属性等来生成一个64位的Hash字段

 

以上是关于序列化和反序列化的主要内容,如果未能解决你的问题,请参考以下文章

C#关于序列化和反序列化

Java的序列化和反序列化

Java的序列化和反序列化

序列化和反序列化

C#序列化和反序列化到底是啥意思?

Dubbo中Map类型默认的序列化和反序列化