序列化(Serializable接口)

序列化是什么:


序列化就是将一个对象的状态(各个属性量)保存起来,然后在适当的时候再获得。
序列化分为两大部分:序列化和反序列化。序列化是这个过程的第一部分,将数据分解成字节流,以便存储在文件中或在网络上传输。反序列化就是打开字节流并重构对象。对象序列化不仅要将基本数据类型转换成字节表示,有时还要恢复数据。恢复数据要求有恢复数据的对象实例。

序列化有什么特点:


如果某个类能够被序列化,其子类也可以被序列化。声明为static和transient类型的成员数据不能被序列化。因为static代表类的状态, transient代表对象的临时数据。

 
什么时候使用序列化:

一:对象序列化可以实现分布式对象。主要应用例如:RMI要利用对象序列化运行远程主机上的服务,就像在本地机上运行对象时一样。
二:对象序列化不仅保留一个对象的数据,而且递归保存对象引用的每个对象的数据。可以将整个对象层次写入字节流中,可以保存在文件中或在网络连接上传递。利用对象序列化可以进行对象的"深复制",即复制对象本身及引用的对象本身。序列化一个对象可能得到整个对象序列。

 

序列化的实现方法:

实现Serializable接口。

 

序列化的使用:

没有implements Serializable,你就不能通过rmi(包括ejb)提供远程调用。

      serialization 允许你将实现了Serializable接口的对象转换为字节序列,这些字节序列可以被完全存储以备以后重新生成原来的对象。

      serialization不但可以在本机做,而且可以经由网络操作(就是猫小说的RMI)。这个好处是很大的----因为它自动屏蔽了操作系统的差异,字节顺序等。比如,在Window平台生成一个对象并序列化之,然后通过网络传到一台Unix机器上,然后可以在这台Unix机器上正确地重构这个对象。

Object serialization主要用来支持2种主要的特性:

     1.Java的RMI(remote method invocation).RMI允许象在本机上一样操作远程机器上的对象。当发送消息给远程对象时,就需要用到serializaiton机制来发送参数和接收返回直。

      2.Java的JavaBeans. Bean的状态信息通常是在设计时配置的。Bean的状态信息必须被存起来,以便当程序运行时能恢复这些状态信息。这也需要serializaiton机制。

 

 

下面是关于serializable的一个例子,如果MyClass不实现serializable,程序将抛出异常。

 

import java.io.*;  

 

public class SerializationDemo{  

        public static void main(String args[]){  

// serialization  

    try{  

    MyClass object1=new MyClass("Hello",-7,2.7e10);  

    System.out.println("object1:"+object1);  

    FileOutputStream fos=new FileOutputStream("serial");  

    ObjectOutputStream oos=new ObjectOutputStream(fos);  

    oos.writeObject(object1);  

    oos.flush();  

    oos.close();  

    }catch(Exception e){  

            System.out.println("Exception during serialization:"+e);  

            System.exit(0);  

    }  

// deserialization  

    try{  

    MyClass object2;  

    FileInputStream fis=new FileInputStream("serial");  

    ObjectInputStream ois=new ObjectInputStream(fis);  

    object2=(MyClass)ois.readObject();  

    ois.close();  

    System.out.println("object2:"+object2);  

    }catch(Exception e){  

        System.out.println("Exception during deserialization:"+e);  

        System.exit(0);  

    }  

    }  

}  

02.------MyClass.java  

class MyClass implements Serializable{  

    String s;  

    int i;  

    double d;  

    public MyClass(String s,int i,double d){  

        this.s=s;  

        this.i=i;  

        this.d=d;  

    }  

    public String toString(){  

        return "s="+s+";i="+i+";d="+d;  

    }  

}  

如果不需要序列化属性就注释为translent

总之如果在网络的环境下做类传输,应该还是应该implements Serializable.

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值