Java序列化概述
- Java序列化就是指把Java对象转换为字节序列的过程
- Java反序列化就是指把字节序列恢复为Java对象的过程。
序列化最重要的作用:
在传递和保存对象时.保证对象的完整性和可传递性。对象转换为有序字节流,以便在网络上传输或者保存在本地文件中。
反序列化的最重要的作用:
根据字节流中保存的对象状态及描述信息,通过反序列化重建对象,芳方便操作。
总结:核心作用就是对象状态的保存和重建。(整个过程核心点就是字节流中所保存的对象状态及描述信息)
举例:
json/xml的数据传递:
在数据传输(也可称为网络传输)前,先通过序列化工具类将Java对象序列化为json/xml文件。
在数据传输(也可称为网络传输)后,再将json/xml文件反序列化为对应语言的对象
2.序列化优点:
①将对象转为字节流存储到硬盘上,当JVM停机的话,字节流还会在硬盘上默默等待,等待下一次JVM的启动,把序列化的对象,通过反序列化为原来的对象,并且序列化的二进制序列能够减少存储空间(永久性保存对象)。
②序列化成字节流形式的对象可以进行网络传输(二进制形式),方便了网络传输。就是String,字节流
③通过序列化可以在进程间传递对象。比如rabbitm的传递,可以传实现序列化的类的对象
3、序列化算法需要做的事:
① 将对象实例相关的类元数据输出。
② 递归地输出类的超类描述直到不再有超类。
③ 类元数据输出完毕后,从最顶端的超类开始输出对象实例的实际数据值。
④ 从上至下递归输出实例的数据
Java实现序列化和反序列化的过程
1、实现序列化的必备要求:
只有实现了Serializable或者Externalizable接口的类的对象才能被序列化为字节序列。(不是则会抛出异常)
2、JDK中序列化和反序列化的API:
-
java.io.ObjectOutputStream:对象输出流序列化就是字节流readObject到硬件,jvm挂了,对象还存在,二进制还节省空间。
该类的writeObject(Object obj)方法将将传入的obj对象进行序列化,把得到的字节序列写入到目标输出流中进行输出。 -
java.io.ObjectInputStream:对象输入流反序列化
该类的readObject()方法从输入流中读取字节序列,然后将字节序列反序列化为一个对象并返回。
看看实现:
package com.mbyte.easy.mailInfo.entity;//重点包路经相同
import java.io.Serializable;
@Data
@AllArgsConstructor
@NoArgsConstructor
public class MailTemplate implements Serializable {
private static final long serialVersionUID=2L;
private String email;
}
假如是一个项目的话,反序列化只用给出那个serialVersionUID,因为超类信息是一样的,