1、序列化和反序列化的概念java
把对象转换为字节序列的过程称为对象的序列化服务器
把字节序列恢复为对象的过程称为对象的反序列网络
对象的序列化主要有两种用途:并发
- 把对象的字节序列永久地保存到硬盘上,一般存放在一个文件中 - 在网络上传送对象的字节序列
在不少应用中,须要对某些对象进行序列化,让它们离开内存空间,入住物理硬盘,以便长期保存。好比最多见的是Web服务器中的Session对象,当有 10万用户并发访问,就有可能出现10万个Session对象,内存可能吃不消,因而Web容器就会把一些seesion先序列化到硬盘中,等要用了,再把保存在硬盘中的对象还原到内存中。code
当两个进程在进行远程通讯时,彼此能够发送各类类型的数据。不管是何种类型的数据,都会以二进制序列的形式在网络上传送。发送方须要把这个Java对象转换为字节序列,才能在网络上传送;接收方则须要把字节序列再恢复为Java对象。对象
2、serialVersionUID的做用接口
serialVersionUID: 字面意思上是序列化的版本号,凡是实现Serializable接口的类都有一个表示序列化版本标识符的静态变量。 假如一个通过了序列化的实体没有写明serialVersionUID,那么java在编译类为class的时候就会自动添加一个serialVersionUID,serialVersionUID的取值是Java运行时环境根据类的内部细节自动生成的。若是对类的源代码做了修改,再从新编译,新生成的类文件的serialVersionUID的取值有可能也会发生变化。第一次编译启动我将对象写入的磁盘,第二次修改类后编译启动我将对象读出将会抛出java.io.InvalidClassException异常,这就是版本号不一致致使的,若是我在类中写定了将不会抛出异常。 显式地定义serialVersionUID有两种用途:进程