本文转自:https://blog.csdn.net/m0_37450089/article/details/78542825
序列化就是一种用来处理对象流的机制,所谓对象流也就是将对象的内容进行流化(将对象转换成二进制)。可以对流化后的对象进行读写操作,也可将流化后的对象传输于网络之间,序列化是为了解决在对对象流进行读写操作时所引发的问题。把对象转换为字节序列的过程称为对象的序列化,把字节序列恢复为对象的过程称为对象的反序列化。
序列化的实现:将需要被序列化的类实现Serializable接口,该接口没有需要实现的方法,implements Serializable只是为了标注该对象是可被序列化的,然后使用一个输出流(如:FileOutputStream)来构造一个ObjectOutputStream(对象流)对象,接着,使用ObjectOutputStream对象的writeObject(Object obj)方法就可以将参数为obj的对象写出(即保存其状态),要恢复的话则用输入流。
在java中如何实现序列化: 首先我们要把准备要序列化类,实现 Serializabel接口 例如:我们要Person类里的name和age都序列化
- import java.io.Serializable;
- public class Person implements Serializable {
- //本类可以序列化
- private String name ;
- private int age ;
- public Person(String name,int age)
- {
- this.name = name ; this.age = age ;
- }
- public String toString()
- {
- return "姓名:" + this.name + ",年龄" + this.age ;
- }
- }
然后:我们将name和age序列化(也就是把这2个对象转为二进制,统族理解为“打碎”)
- package org.lxh.SerDemo;
- import java.io.File;
- import java.io.FileOutputStream;
- import java.io.ObjectOutputStream ;
- public class ObjectOutputStreamDemo
- {
- //序列化
- public static void main(String[] args) throws Exception
- {
- //序列化后生成指定文件路径
- File file = new File("D:" + File.separator + "person.ser") ;
- ObjectOutputStream oos = null ;
- //装饰流(流)
- oos = new ObjectOutputStream(new FileOutputStream(file)) ;
- //实例化类
- Person per = new Person("张三",30) ;
- oos.writeObject(per) ;
- //把类对象序列化
- oos.close() ;
- }
- }
对象的序列化主要有两种用途:
1) 把对象的字节序列永久地保存到硬盘上,通常存放在一个文件中;
2) 在网络上传送对象的字节序列。
在很多应用中,需要对某些对象进行序列化,让它们离开内存空间,入住物理硬盘,以便长期保存。比如最常见的是Web服务器中的Session对象,当有10万用户并发访问,就有可能出现10万个Session对象,内存可能吃不消,于是Web容器就会把一些seesion先序列化到硬盘中,等要用了,再把保存在硬盘中的对象还原到内存中。
当两个进程在进行远程通信时,彼此可以发送各种类型的数据。无论是何种类型的数据,都会以二进制序列的形式在网络上传送。发送方需要把这个Java对象转换为字节序列,才能在网络上传送;接收方则需要把字节序列再恢复为Java对象。