实现Vector对象的序列化 将Vector对象压入标准流
Vector对象是一个很灵活的java数据结构,在实际编程中,有时需要我们将一个Vector对象传递给另一个Java程序并保持Vector的数据结构状态,这时,我们可以将需要传递的对象实现java.io.Serializable接口,序列化这个类,由于序列化本身就是允许一个对象在虚拟机之间传送(或者经过一段空间,如在RMI中;或者经过一段时间,比如数据流被保存到一个文件中)。 关于类的序列化请查阅相关资料,本篇不在叙述,下面使用一个简单的程序说明如何把一个Vector对象序列化并放到一个流中(为了测试方便,这里放到一个文件流中,如果换成一个套接字就可以把对象发送给远程请求者)
程序1:把一个Vector对象存储到一个testvector.obj文件里(模拟server socket处理)
Code:
import java.io.*; import java.util.*; class TestVector implements java.io.Serializable{ private Vector vect=new Vector(); public void add(Object obj){ this.vect.add(obj); } public void print(){ System.out.println(this.vect); } public static void main(String[] args){ try { /* 将对象写到一个文件里 */ FileOutputStream objfile = new FileOutputStream("testvector.obj"); /* 创建一个输出流 */ ObjectOutputStream p = new ObjectOutputStream(objfile); /* 创建一个TestVector对象 */ TestVector tv =new TestVector(); /*给Vector写入几String个对象*/ tv.add("One"); tv.add("Two"); tv.add("Three"); p.writeObject(tv); // 把tv写入流 p.flush(); objfile.close(); // 关闭文件对象 } catch (Exception e) { e.printStackTrace(); } } } |