对象序列化机制对于需要将对象的状态保存到文件中,而后能够通过读入对象状态来重新构造对象,恢复程序状态,或者使用套接字在网络上传送对象的程序来说,是很有用的。通过让类实现java.io.Serializable 接口可以将类序列化。这个接口是一个制造者(marker)接口。也就是说,对于要实现它的类来说,该接口不需要实现任何方法。它主要用来通知Java虚拟机(JVM)需要将一个对象序列化。
也叫串行化,对象的域转化为紧凑的2进制形式,是对象持久化的方法之一。《实现类的序列化--例子将Vector对象压入标准流》出处 CN-JAVA原创:jackliuVector对象是一个很灵活的java数据结构,在实际编程中,有时需要我们将一个Vector对象传递给另一个Java程序并保持Vector的数据结构状态,这时,我们可以将需要传递的对象实现java.io.Serializable接口,序列化这个类,由于序列化本身就是允许一个对象在虚拟机之间传送(或者经过一段空间,如在RMI中;或者经过一段时间,比如数据流被保存到一个文件中)。 关于类的序列化请查阅相关资料,本篇不在叙述,下面使用一个简单的程序说明如何把一个Vector对象序列化并放到一个流中(为了测试方便,这里放到一个文件流中,如果换成一个套接字就可以把对象发送给远程请求者)
程序1:把一个Vector对象存储到一个testvector.obj文件里(模拟server socket处理)
编译程序1,运行后,在当前目录生成一个testvector.obj文件,这个文件里存放了TestVector类的数据
程序2:从testvector.obj文件里获取TestVector对象(模拟socke客户端)
编译程序2,运行后,读取testvector.obj文件,根据内容构建出原始的TestVector类。
posted on 2005-11-09 09:52 bluesky 阅读(782) 评论(0) 编辑 收藏 所属分类: 基础知识