Serializable的用法

[size=medium]

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

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


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

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

代码:

[size=medium][/size][size=x-large][/size]import java.io.*;


public class SerializationDemo{

public static void main(String args[]){


//Object 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);

}


//Object 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);

}

}

}


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;

}

}


程序运行结果:object1和object2的实例变量是一样的,输出如下:

object1:s=Hello;i=-7;d=2.7E10

object2:s=Hello;i=-7;d=2.7E10
]
[/size]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值