Java对象的序列化和反序列化
一、序列化和反序列化的概念
把对象转换为字节序列的过程称为对象的序列化。
把字节序列恢复为对象的过程称为对象的反序列化。
对象的序列化主要有两种用途:
1) 把对象的字节序列永久地保存到硬盘上,通常存放在一个文件中;
2) 在网络上传送对象的字节序列。
二、什么场景会涉及序列化和反序列化的概念
在很多应用中,需要对某些对象进行序列化,
让它们离开内存空间,入住物理硬盘,以便长期保存。
比如最常见的是Web服务器中的Session对象,
当有 10万用户并发访问,就有可能出现10万个Session对象,
内存可能吃不消,于是Web容器就会把一些session先序列化到硬盘中,
等要用了,再把保存在硬盘中的对象还原到内存中。
当两个进程在进行远程通信时,彼此可以发送各种类型的数据。
无论是何种类型的数据,都会以二进制序列的形式在网络上传送。
发送方需要把这个Java对象转换为字节序列,才能在网络上传送;
接收方则需要把字节序列再恢复为Java对象。
【1】对象序列化代码如下
package yxzy.demo1.demo1;
import java.io.*;
public class TestStudent1 {
public static void main(String[] args) {
// 实例化一个对象
Student stu=new Student("小明",18,"xiaoming");
// 将这个对象序列化到对象中去
File file=new File("student.bat");
// 创建一个文件写入流
FileOutputStream fos;
try {
fos = new FileOutputStream(file);
ObjectOutputStream oos = new ObjectOutputStream(fos);
oos.writeObject(stu);
oos.close();
fos.close();
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
}
}