1. 为什么要序列化?
对象的寿命通常随着生成该对象的程序的终止而终止。有时候,可能需要将对象的状态保存下来,在需要时再将对象恢复。我们把对象的这种能记录自己的状态以便将来再生的能力。叫作对象的持续性(persistence)。对象通过写出描述自己状态的数值来记录自己 ,这个过程叫对象的序列化(Serialization) 。
简而言之:由于对象生命周期的存在;有时候希望对象具有持久性,于是就有了串行化
序列化的本质:
将 Java 对象序列化为二进制文件
序列化应用场景举例:
1. 两个客户端clientA 和 clientB 试图通过网络传递对象数据ObjectC。 clientA 端将对象 ObjectC 序列化为二进制数据再传给 ClientB,clientB 反序列化得到 ObjectC。
2. ...
2. 如何实现序列化?
开发人员只需要将被序列化的类实现 java.io. Serializable 接口,使用 ObjectInputStream 和 ObjectOutputStream 进行对象的读写。看看JDK中对接口Serializable的说明
public interface Serializable
类通过实现java.io.Serializable 接口以启用其序列化功能。未实现此接口的类将无法使其任何状态序列化或反序列化。可序列化类的所有子类型本身都是可序列化的。序列化接口没有方法或字段,仅用于标识可序列化的语义。
实例
public class SerializableDemo {
public static void main(String[] args) {
try {
PersonSerilz sPerson = new PersonSerilz("LiLei", 12);
System.out.println(sPerson.toString());
ObjectOutputStream out = new ObjectOutputStream(new FileOutputStream("/sPerson.data"));
out.writeObject(sPerson);
out.close();
ObjectInputStream in = new ObjectInputStream(new FileInputStream("/sPerson.data"));
PersonSerilz inverSPerson = (PersonSerilz) in.readObject();
in.close();
// 先将一个对象序列化后保存在文件中,然后又通过反序列化将对象从文件中读出来,如果打印结果一致,表示序列化成功
System.out.println(inverSPerson.toString());
// 将一个非序列化对象写到文件中,会怎样?会输出java.io.NotSerializableException
// Person ordPerson = new Person("HanMeimei", 13);
// out = new ObjectOutputStream(new FileOutputStream("ordPerson.data"));
// out.writeObject(ordPerson);
// out.close();
} catch (Exception e) {
e.printStackTrace();
}
}
}
参考:http://www.cnblogs.com/vicenteforever/articles/1471775.html