一、前言
本人java小白一枚,从零开始学习java有关的内容,本篇权当一个学习记录的过程,如果有什么不对的地方,欢迎各位留言。
二、什么是序列化和反序列化
(1)序列化:把Java对象转换为字节序列的过程。
(2)反序列化:把字节序列恢复为Java对象的过程。
三、为什么要进行序列化和反序列化
(1)持久化对象:把对象的字节序列永久地保存到硬盘上,通常存放在一个文件夹中
在很多应用中,需要对某些对象进行序列化,让它们离开内存空间,入住物理硬盘,以便长期保存。比如最常见的是Web服务器中的Session对象,当有 10万用户并发访问,就有可能出现10万个Session对象,内存可能吃不消,于是Web容器就会把一些session先序列化到硬盘中,等要用了,再把保存在硬盘中的对象还原到内存中。
(2)网络传输对象:在网络上传送对象的字节序列
当两个进程在进行远程通信时,彼此可以发送各种类型的数据。无论是何种类型的数据,都会以二进制序列的形式在网络上传送。发送方需要把这个Java对象转换为字节序列,才能在网络上传送;接收方则需要把字节序列再恢复为Java对象。
四、怎样进行序列化和反序列化
(1)序列化的条件:只有实现了Serializable或者Externalizable接口的类的对象才能被序列化为字节序列。
(2)序列化的方法:
①java.io.ObjectInputStream:对象输入流。
该类的readObject()方法从输入流中读取字节序列,然后将字节序列反序列化为一个对象并返回。
②java.io.ObjectOutputStream:对象输出流。
该类的writeObject(Object obj)方法将将传入的obj对象进行序列化,把得到的字节序列写入到目标输出流中进行输出。
五、序列化代码演示
(1)创建Person类,调用Serializable接口,以能够被序列化
public class Person implements Serializable {
private static final long serialVersionUID = -3288773023616717564L;
private int age;
private String name;
private String sex;
}
public int getAge() {
return age;
}
public String getName() {
return name;
}
public String getSex() {
return sex;
}
public void setAge(int age) {
this.age = age;
}
public void setName(String name) {
this.name = name;
}
public void setSex(String sex) {
this.sex = sex;
}
}
(2)创建ObjectSerialize类,编写SerializePerson()方法,初始化person对象,并对该对象进行序列化,序列化过后的字节序列存放到"./Person.txt"文件中
public class ObjectSerialize {
public static void main(String[] args) throws IOException {
SerializePerson();
}
private static void SerializePerson() throws FileNotFoundException,
IOException {
// 实例化Person对象
Person person = new Person();
person.setName("Hacker");
person.setAge(25);
person.setSex("Male");
// 创建对象输出流,将对象输出到文件"./Person.txt"中
ObjectOutputStream oos = new ObjectOutputStream(new FileOutputStream(
new File("./Person.txt")));
// 对象输出流写出对象
oos.writeObject(person);
System.out.println("Person对象序列化成功!");
oos.close();
}
}
用vim打开Person.txt,在命令行模式下, 输入以下命令::%!xxd查看序列化的内容如下:
(3)创建 ObjectDeserialize类,编写DeserializePerson()方法,从"./Person.txt"文件中读取序列化的对象,并输出对象的内容。
public class ObjectDeserialize {
public static void main(String[] args) throws Exception {
Person person = DeserializePerson();
System.out.println(MessageFormat.format("name={0}," +
"age={1},sex={2}",person.getName(), person.getAge(),person.getSex()));
}
private static Person DeserializePerson() throws Exception, IOException {
// 创建对象输入流从"./Person.txt"中读取对象
ObjectInputStream ois = new ObjectInputStream(new FileInputStream(
new File("./Person.txt")));
// 读取对象并返回给Person
Person person = (Person) ois.readObject();
System.out.println("Person 对象反序列化成功!");
return person;
}
}
参考资料
[1] https://www.jianshu.com/p/89c2a19772e2
[2] https://www.zhihu.com/question/47794528/answer/672095170