java 序列化和反序列化和serialVersionUID

1、序列化和反序列化的概念java

把对象转换为字节序列的过程称为对象的序列化服务器

把字节序列恢复为对象的过程称为对象的反序列网络

对象的序列化主要有两种用途:并发

- 把对象的字节序列永久地保存到硬盘上,一般存放在一个文件中

     - 在网络上传送对象的字节序列

  在不少应用中,须要对某些对象进行序列化,让它们离开内存空间,入住物理硬盘,以便长期保存。好比最多见的是Web服务器中的Session对象,当有 10万用户并发访问,就有可能出现10万个Session对象,内存可能吃不消,因而Web容器就会把一些seesion先序列化到硬盘中,等要用了,再把保存在硬盘中的对象还原到内存中。code

  当两个进程在进行远程通讯时,彼此能够发送各类类型的数据。不管是何种类型的数据,都会以二进制序列的形式在网络上传送。发送方须要把这个Java对象转换为字节序列,才能在网络上传送;接收方则须要把字节序列再恢复为Java对象。对象

2、serialVersionUID的做用接口

s​e​r​i​a​l​V​e​r​s​i​o​n​U​I​D​:​ ​字​面​意​思​上​是​序​列​化​的​版​本​号​,凡是实现Serializable接口的类都有一个表示序列化版本标识符的静态变量。 假如一个通过了序列化的实体没有写明serialVersionUID,那么java在编译类为class的时候就会自动添加一个serialVersionUID,serialVersionUID的取值是Java运行时环境根据类的内部细节自动生成的。若是对类的源代码做了修改,再从新编译,新生成的类文件的serialVersionUID的取值有可能也会发生变化。第一次编译启动我将对象写入的磁盘,第二次修改类后编译启动我将对象读出将会抛出java.io.InvalidClassException异常,这就是版本号不一致致使的,若是我在类中写定了将不会抛出异常。 显式地定义serialVersionUID有两种用途:进程

  • 在某些场合,但愿类的不一样版本对序列化兼容,所以须要确保类的不一样版本具备相同的serialVersionUID
  • 在某些场合,不但愿类的不一样版本对序列化兼容,所以须要确保类的不一样版本具备不一样的serialVersionUID
相关文章
相关标签/搜索