序列化 / 反序列化
概述:序列化 (Serialization)是将对象的状态信息转换为可以存储或传输的形式的过程。
- 在序列化期间,对象将其当前状态写入到临时或持久性存储区。以后,可以通过从存储区中读取或反序列化对象的状态,重新创建该对象。
序列化:利用ObjectOutputStream,对象的信息,按固定格式转成一串字节值输出并持久保存到磁盘化。
- 反序列化:利用ObjectInputStream,读取磁盘中序列化数据,重新恢复对象。
特点/应用场景:
- 需要序列化的文件必须实现Serializable接口以启用其序列化功能。
- 不需要序列化的数据可以被修饰为static的,由于static属于类,不随对象被序列化输出。
- 不需要序列化的数据也可以被修饰为transient临时的,只在程序运行期间,在内存中存在不会被序列化持久保存。
- 在反序列化时,如果和序列化的版本号不一致时,无法完成反序列化。
- 每个被序列化的文件都有一个唯一id,如果没有添加编译器会根据类的定义信息计算产生一个版本号。
- 常用于服务器之间的数据传输,序列化成文件,反序列化读取数据。
- 常用于使用套接字流在主机之间传递对象。
ObjectOutputStream
ObjectOutputStream
- 将 Java 对象的基本数据类型和图形写入 OutputStream。可以使用 ObjectInputStream 读取(重构)对象。通过在流中使用文件可以实现对象的持久存储。
> -- ObjectOutputStream(OutputStream out)
创建写入指定 OutputStream 的 ObjectOutputStream。
> -- void writeObject(Object obj)
将指定的对象写入 ObjectOutputStream。
ObjectInputStream
ObjectInputStream
- 对以前使用 ObjectOutputStream 写入的基本数据和对象进行反序列化。
> -- ObjectInputStream(InputStream in)
创建从指定 InputStream 读取的 ObjectInputStream。
> -- Object readObject()
从 ObjectInputStream 读取对象,读取序列化数据。
将学生信息序列化至磁盘【序列化】
public class Seri {
public static void main(String[] args) throws Exception, IOException {
//序列化:就是把java对象保存在磁盘中
ObjectOutputStream os =
new ObjectOutputStream(
new FileOutputStream( "D:\\teach\\a\\student.txt"));
Student s = new Student("张三",20,"成都");
os.writeObject(s);
os.close();//关闭输出资源
//反序列化:从磁盘读到程序里
ObjectInputStream in =
new ObjectInputStream(
new FileInputStream(
"D:\\teach\\a\\student.txt"));
//读到的对象,默认是Object,需要强转成子类
Student s2 = (Student)in.readObject();
System.out.println(s2);
}
}
//1,如果想完成序列化,类必须实现Serializable接口
//只是用来做标记,需要序列化
class Student implements Serializable{
//创建对象用
public Student(String name, int age, String addr) {
this.name = name;
this.age = age;
this.addr = addr;
}
//一般序列化的都是属性
String name = "张三";
int age = 20;
String addr = "成都";
//为了看属性值
@Override
public String toString() {
return "Student [name=" + name + ", age=" + age + ", addr=" + addr + "]";
}
}