一 序列化
Java的”对象序列化“能将一个实现了serializable接口的对象转换成一组byte,这样日后要用到这个对象的时候,就能把这些byte数据恢复出来,并据此重新构建那个对象。这一点甚至在跨网络的环境下也是如此,这就意味着序列化机制能自动补偿操作系统方面的差异。也就是说,可以在Windows机器上创建一个对象,序列化之后,再通过网络传到Unix机器上,最后在那里进行重建。不用担心在不同的平台上数据是怎样表示的,以及byte顺序怎洋,或者别的细节。
之所以要在语言中加入对象序列化,是因为要用它来实现两个重要的功能
(1)Java的远程方法调用(RMI)能像调用自己机器上的对象那样去调用其他机器上的对象。当向远程对象传递消息的时候,就需要通过对象序列化来传送参数和返回值。
(2)对javabean来说,对象序列化也是必不可少的,bean的状态信息通常是在设计时配置的,这些状态信息必须保存起来,供程序启动的时候用,对象序列化就负责这个工作。
二 持久化
对象序列化能实现”轻量的持久化“。所谓持久化,是指对象的生命周期不是由程序是否运行决定的,在程序的两次调用之间对象仍然活着。通过”将做过序列化处理的对象写入磁盘,等到程序再次运行的时候再把它读出来”,可以达到持久化的效果。
三 Java中实现对象序列化
要想序列化对象,必须先创建一个OutputStream,然后把它嵌进ObjectOutputStream,这时就能用writeObject()方法把对象写入OutputStream
读的时候需要把InputStream嵌到ObjectInputStream中,然后在调用readObject()方法,不过这样读出来的只是一个Object的引用,在用之前,还需要往下传。
import java.io.*;
public class Box implements Serializable
{
private int width;
private int height;
public void setWidth(int width){
this.width = width;
}
public void setHeight(int height){
this.height = height;
}
public static void main(String[] args){
Box myBox = new Box();
myBox.setWidth(50);
myBox.setHeight(30);
try{
FileOutputStream fs = new FileOutputStream("foo.ser");
ObjectOutputStream os = new ObjectOutputStream(fs);
os.writeObject(myBox);
os.close();
}catch(Exception ex){
ex.printStackTrace();
}
}
}
什么情况下需要序列化
a)当你想把的内存中的对象状态保存到一个文件中或者数据库中时候;
b)当你想用套接字在网络上传送对象的时候;
c)当你想通过RMI传输对象的时候;