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);
    }
    }
}

------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;
    }
}

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

 

 

你可能感兴趣的:(JAVA)