序列化定义:就是一种用来处理对象流的机制,所谓对象流也就是将对象的内容进行流化(将对象转换成二进制)。可以对流化后的对象进行读写操作,也可将流化后的对象传输于网络之间。
序列化目的:为了解决在对 对象流进行读写操作时所引发的问题。
序列化,把字节序列恢复为对象的过程称为对象的反序列化。
序列化是将对象的状态信息(也就是实例变量) → 可以存储或传输的格式 的过程。
反序列化是通过从存储或者网络读取对象的状态 → 重新创建该对象。
————————————————————————————————————————————
要实现序列化之前,先要了解一个接口:Serializable接口。
Java提供的Serializable接口是一个空接口;如果一个类实现了Serializable接口,说明:
1)、那么就代表这个类以及其子类是自动支持序列化和反序列化的,
2)、序列化时,只对对象的状态进行保存,而不管对象的方法。如果一个类没有实现Serializable接口,那么默认是不能被序列化的,除非使用其他办法。
3)、如果一个类实现了Serializable接口,其父类没有实现Serializable接口,那么父类必须有无参的构造器,并且父类中的状态默认不能被序列化。
4)、序列化的实例变量引用其他对象,则引用对象也会被序列化;
5)、并非所有的对象都可以序列化。
在什么情况下需要使用到Serializable接口呢?
1)、当想把内存中的对象状态保存到一个文件中或者数据库中时候;
2)、当想用套接字在网络上传送对象的时候;
3)、当想通过RMI传输对象的时候;
————————————————————————————————————————————
如何实现序列化: 首先我们要准备好要序列化类,再来实现 Serializabel接口 。
序列化的实现过程:
将需要被序列化的类实现Serializable接口,该接口没有需要实现的方法,implements Serializable只是为了标注该对象是可被序列化的,然后使用一个输出流(如:FileOutputStream)来构造一个ObjectOutputStream(对象流)对象,接着使用ObjectOutputStream对象的writeObject(Object obj)方法就可以将参数为obj的对象写出(即保存其状态),要恢复的话则用输入流。
例子:
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) 在网络上传送对象的字节序列。