黑马程序员技术交流社区
标题:
【广州校区】序列化和反序列化简单理解
[打印本页]
作者:
码农苏尼玛
时间:
2019-6-20 15:56
标题:
【广州校区】序列化和反序列化简单理解
序列化与反序列化的概念
直白的认为是对象转换为字节序列的过程为对象序列化
反之字节序列复原为对象的过程叫对象反序列化
对象的序列化有两种方法
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运行时候环境根据内部细节自动生成,如果类的源代码修改则重新编译生成类文件
取值也相对变化
欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/)
黑马程序员IT技术论坛 X3.2