A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

序列化与反序列化的概念
直白的认为是对象转换为字节序列的过程为对象序列化
反之字节序列复原为对象的过程叫对象反序列化
对象的序列化有两种方法
1.把对象的字节序列数据永久保存到硬盘,这是常规做法
2.在网络传送对象的字节序列化数据
很多应用,需要对象进行序列化,让他们脱离内存空间,持久保存到物理硬盘得以长期保存下来
比如常见的web服务器的session对象,假设存在10000个用户同时访问,就有10000个session对象存在
内存消耗异常巨大,于是web就应该将session对象序列化到硬盘中,使用的时候直接实例化对象到内存里
当两个进程进行通信,彼此发送数据,无论哪种类型数据,都会成为二进制序列化在网络传送,发送者需要把java对象序列化为字节码
才能实现网络传送,接收者直接把字节码序列回复为java对象
JDK中的序列化API
ObjectOutputStream 代表对象输出,其中writeObj的方法参数指定obj对象操作实例化,将字节码写在目标输出流
ObjectInputStream 代表对象输入,readObj方法从数据源输入读取字节码序列转为反序列对象并返回
只有Serializable和Externalizable接口的类的对象才能被序列化。


对象序列化过程分几步:
1.创建对象输出流,例如包装文件输出流
2.通过对象输出流writeObj写对象
对象反序列化过程分几步
1.创建对象输入流,包装其他源输入流
2.通过对象输入流的readObj方法读取对象

关于serialVersionUID的用法序列化版本号,凡是Serializable接口的类都具备一个序列化版本标识符
他的取值是java运行时候环境根据内部细节自动生成,如果类的源代码修改则重新编译生成类文件
取值也相对变化




0 个回复

您需要登录后才可以回帖 登录 | 加入黑马