什么是序列化(serializable)
Serializable接口是启用其序列化功能的接口。实现java.io.Serializable 接口的类是可序列化的。没有实现此接口的类将不能序列化或者逆序列化。
序列化:就是把对象转化成字节。
反序列化:把字节数据转换成对象。
应用场景
1、将对象通过网络传输
例如:在微服务系统中或给第三方提供接口调用时,使用rpc进行调用,一般会把对象转化成字节序列,才能在网络上传输;接收方则需要把字节序列再转化为java对象。
2、对象保存至本地存储中
例如:hibernate中的二级缓存:把从数据库中查询出的对象,序列化转存到硬盘中,下次读取的时候,首先从内存中找是否有该对象,如果没有在去二级缓存(硬盘)中去查找。减少数据库的查询次数,提升性能。
如何实现对象的序列化
利用ObjectInputStream 和 ObjectOutputStream类
Java IO 包中为我们提供了 ObjectInputStream 和 ObjectOutputStream 两个类。
java.io.ObjectOutputStream 类实现类的序列化功能。
java.io.ObjectInputStream 类实现了反序列化功能。
//将要序列化的类
package test;
import java.io.Serializable;
public class Person implements Serializable {
int id;
String name;
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
@Override
public String toString() {
return "Person{" +
"id=" + id +
", name='" + name + '\'' +
'}';
}
}
//序列化
package test;
import java.io.*;
public class TestSerializable{
public static void test() throws Exception{
Person p=new Person();
p.setId(3);
p.setName("qq");
File file=new File("D:\\test.txt");
ObjectOutputStream ops=new ObjectOutputStream(new FileOutputStream(file));
ops.writeObject(p);//序列化到本地
System.out.println(p);
ObjectInputStream ois=new ObjectInputStream(new FileInputStream(file));
Person p1=(Person)ois.readObject();//反序列化
System.out.println(p1);
}
public static void main(String[] args){
try{
test();
}catch (Exception e){
e.printStackTrace();
}
}
}
transient关键字的使用
当某个字段被声明为transient后,序列化机制就会忽略该字段。该字段的值不会被序列化,序列化结束后该字段的值为null