何为对象序列化:
指将一个Java对象写入IO流中,与此相对应的是,对象的反序列化(Deserialize),则指从IO流中恢复该Java对象。
序列化机制:
将实现序列化的Java对象转换成字节序列,这些字节序列可以保存在磁盘上,或者通过网路传输,以备以后重新恢复原来的对象。序列化机制使得对象可以脱离程序的运行而独立存在。
换种说法:对象序列化机制允许把内存中的Java对象转换成平台无关的二进制流,从而允许把这种二进制流持久的保存在磁盘上,通过网络将这种二进制流传输到另一个网络节点。其他程序一旦获得了这种二进制流,都可以将这种二进制流恢复成原来的Java对象。
如果需要让某个对象支持序列化机制,则必须让它的类是可序列化的,实现该类可序列化,该类必须实现如下两个接口之一:
- Serializable
- Externalizable
一旦某个类实现了Serializable接口,该类的对象就是可序列化的。步骤如下:
- 创建一个ObjectOutputStream,这个输出流是一个处理流。
- 调用ObjectOutputStream对象的writeObject()方法输出可序列化对象。
举个例子:
public class Person implements java.io.Serializable
{
private String name;
private int age;
public Person(String name, int age){
this.name = name;
this.age = age;
}
//........
}
下面程序使用ObjectOutputStream将一个Person对象写入磁盘文件中。
public class WriteObject
{
public static void main(String[] args){
try {
ObjectOutputStream objectOutputStream = new ObjectOutputStream(new FileOutputStream("object.txt"));
Person person = new Person("Pengyan", 25);
objectOutputStream.writeObject(person);
} catch (Exception e) {
e.printStackTrace();
}
}
}
运行上面程序后,将会看到生成了一个object.txt文件,该文件的对象就是Person对象。
如果要从二进制流中恢复Java对象,则需要使用反序列化。反序列化步骤如下:
(1)创建一个ObjectInputStream输入流;
(2)调用ObjectInputStream对象的readObject()方法。
下面程序示范从刚刚生成的object.txt文件中读取Person对象。
public class ReadObject {
public static void main(String[] args) {
try {
ObjectInputStream objectInputStream = new ObjectInputStream(new FileInputStream("object.txt"));
Person person = (Person)objectInputStream.readObject();
System.out.println("名字为:"+person.getName()+"\n年龄为"+person.getAge());
} catch (Exception e) {
e.printStackTrace();
}
}
}
如果使用序列化机制向文件中写入了多个Java对象,使用反序列化机制恢复对象时必须按照实际写入的顺序读取。