序列化与反序列化
把Java对象转换为字节序列的过程称为对象的序列化。
把字节序列恢复为Java对象的过程称为对象的反序列化。
序列化的必要性
Java中,一切都是对象,在分布式环境中经常需要将Object从这一端网络或设备传递到另一端。这就需要有一种可以在两端传输数据的协议。Java序列化机制就是为了解决这个问题而产生。
如何序列化一个对象
一个对象能够序列化的前提是实现Serializable接口,Serializable接口没有方法,更像是个标记。有了这个标记的Class就能被序列化机制处理。
ObjectOutputStream 把Object输出成Byte流,保存在文件中
ObjectInputStream 从持久的文件中读取Bytes重建对象
下面举个小栗子;
将实现Serializable接口的Person类,序列化写入文件,反序列化从文件读取出来。
public class Person implements Serializable{
private static final long serialVersionUID= 4603642343377807741L; //不加序列号将会出现警告
private int age;
private String name;
private String id;
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
}
public class TestObjSerializeAndDeserialize {
//将对象序列化
private static void serializePerson() throws FileNotFoundException, IOException {
Person person=new Person();
person.setName("张三");
person.setAge(18);
ObjectOutputStream oo=new ObjectOutputStream(new FileOutputStream(new File("D:/Person.txt")));
oo.writeObject(person);
System.out.println("序列化对象成功");
oo.close();
}
//将对象反序列化
private static Person DeserializePerson() throws FileNotFoundException, IOException, ClassNotFoundException {
ObjectInputStream ois=new ObjectInputStream(new FileInputStream(new File("D:/Person.txt")));
Person person=(Person)ois.readObject();
System.out.println("Person对象反序列化成功");
return person;
}
public static void main(String[] args) throws Exception {
serializePerson();//序列化Person
Person p=DeserializePerson();//反序列化Person
System.out.println(MessageFormat.format("name={0},age={1}", p.getName(),p.getAge()));
}
}
参考自:http://developer.51cto.com/art/200908/147650.htm