对象的序列化与反序列化

上传人:宝路 文档编号:48119322 上传时间:2018-07-10 格式:PPT 页数:41 大小:100.74KB
返回 下载 相关 举报
对象的序列化与反序列化_第1页
第1页 / 共41页
对象的序列化与反序列化_第2页
第2页 / 共41页
对象的序列化与反序列化_第3页
第3页 / 共41页
对象的序列化与反序列化_第4页
第4页 / 共41页
对象的序列化与反序列化_第5页
第5页 / 共41页
点击查看更多>>
资源描述

《对象的序列化与反序列化》由会员分享,可在线阅读,更多相关《对象的序列化与反序列化(41页珍藏版)》请在金锄头文库上搜索。

1、对象的序列化与反序列化主要内容概述 当两个进程进行远程通信时,彼此可以发送各 种类型的数据,包括文本图片音频视频等,都 会以二进制序列的形式在网络上传送. 当两个java进程进行通信时,一个进程能否把 一个java对象发送给另一个进程呢?答案是肯定的!概述 如何才能做到呢 1)发送方需要把这个java对象转换为字节序列 ,才能在网上传送 2)接收方需要把字节序列再恢复为java对象. 把java对象转换为字节序列的过程称为对象 的序列化,. 把字节序列恢复为java对象的过程称为对象 的反序列化.序列化与反序列化对象序列化两种用途 把对象的字节序列永久的保存到硬盘上, 通常存放在一个文件中.

2、在网络上传送对象的字节序列.主机1主机2文件网络传输存储到文件9.1.jdk类库中的序列化API 如何才能做到呢 1)发送方需要把这个java对象转换为字节序列 ,才能在网上传送 2)接收方需要把字节序列再恢复为java对象. 把java对象转换为字节序列的过程称为对象 的序列化,. 把字节序列恢复为java对象的过程称为对象 的反序列化.序列化与反序列化9.1jdk类库中的序列化API java.io.ObjectOutputStream:代表对象输出流 它的writeObject(Object obj)方法可对参数指定的obj对 象进行序列化,把得到的字节序列写到一个目标输 出流中。 Ja

3、va.io.ObjectInputStream代表对象输入流, 它的readObject()方法从一个源输入流中读取字节, 再把它们反序列化成一个对象,并将其返回。9.1jdk类库中的序列化API 哪些类可以被序列化呢? 只有实现了Serializable或Externalizable接口的类的对 象才能被序列化,否则ObjectOutputStream的 writeObject(Object obj)方法会抛出IOException。 实现了Serializable或Externalizable接口的类也称为可 序列化类。 Externalizable接口继承Serializable接口,实

4、现 Externalizable接口的类完全由自身来控制序列化的行 为。而仅实现Serializable接口的类可以采用默认的 序列化方式。 Jdk的部分类 如StringDate等都实现了Serializable接口9.1jdk类库中的序列化API 假定一个Customer类,它的对象需要序列化。 可以 有以下三种方式进行 如果customer类仅仅实现了Serializable接口的类,那 么会按照以下方式进行序列化和反序列化: ObjectOutputStream采用默认的序列化方式,对 Customer对象的非transient的实例变量进行序列化。 ObjectInputStream

5、采用默认的反序列化方式,对 customer对象的非transient的实例变量进行反序列化 。9.1jdk类库中的序列化API2. 如果customer类仅仅实现了Serializable接口, 并且还定义了readObject(ObjectInputStream in)和 writeObject(ObjectOutputStream out),那么会按照 以下方式进行序列化和反序列化: ObjectOutputStream会调用Customer对象的 writeObject(ObjectOutputStream out)方法进行序 列化。 ObjectInputStream会调用Custo

6、mer对象的 readObject(ObjectInputStream in)方法进行反序列 化。9.1jdk类库中的序列化API3. 如果customer类实现了Externalizable接口,那 么Customer类必须实现readExternal(ObjectInput in)和writeExternal(ObjectOutput out)方法,那么 会按照以下方式进行序列化和反序列化: ObjectOutputStream会调用Customer对象的 writeExternal(ObjectOutput out)方法进行序列化 。 ObjectInputStream会调用Custom

7、er对象的 readExternal(ObjectInput in)方法进行反序列化。9.1jdk类库中的序列化API类框图9.1jdk类库中的序列化步骤 创建一个对象输出流,它可以包装一个其 他类型的目标输出流,如文件输出流: ObjectOutputStream out = new ObjectOutputStream(new fileOutputStream(“D:objectfile.obj”);9.1jdk类库中的序列化步骤 通过对象输出流的writeObject()方法写对象 ,如: Out.writeObject(“hello”); Out.writeObject(new Dat

8、e();9.1jdk类库中的反序列化步骤 创建一个对象输入流,它可以包装一个其 他类型的源输入流,如文件输入流: ObjectInputStream in = new ObjectInputStream (new fileIutputStream(“D:objectfile.obj”);9.1jdk类库中的反序列化步骤 通过对象输入流的readObject()方法读取对 象,如: String obj1=(String)in.readObject(); Date obj2=(Date)in.readObject(); 为了能正确读取数据,必须保证向对象输 出流写对象的顺序与从对象输入流读对象

9、的顺序一致例9.1jdk类库中序列化程序import java.io.*;import java.util.*; public class ObjectSaver public static void main(String agrs) throws Exception ObjectOutputStream out=new ObjectOutputStream(new FileOutputStream(“D:objectFile.obj“); String obj1=“hello“; Date obj2=new Date(); Customer obj3=new Customer(“Tom“,

10、20); /序列化对象 out.writeObject(obj1); out.writeObject(obj2); out.writeObject(obj3); out.writeInt(123); out.close();例9.1jdk类库中序列化程序/反序列化对象 ObjectInputStream in=new ObjectInputStream(new FileInputStream(“D:objectFile.obj“); String obj11 = (String)in.readObject(); System.out.println(“obj11:“+obj11); Syste

11、m.out.println(“obj11=obj1:“+(obj11=obj1); Date obj22 = (Date)in.readObject(); System.out.println(“obj22:“+obj22); System.out.println(“obj22=obj2:“+(obj22=obj2); Customer obj33 = (Customer)in.readObject(); System.out.println(“obj33:“+obj33); System.out.println(“obj33=obj3:“+(obj33=obj3); int var= in.

12、readInt(); System.out.println(“var:“+var); in.close();例9.1jdk类库中序列化程序 class Customer implements Serializable private String name; private int age; public Customer(String name,int age) this.name=name; this.age=age; public String toString()return “name=“+name+“,age=“+age; 例程9-2 SimpleServer 该服务器从命令行读取

13、用户指定的类名, 创建该类的一个对象,然后向客户端两次 发送这个对象。 结果表明:按照默认方式序列化时,如果 有一个ObjectOutputStream对象多次序列化 同一个对象,那么有一个ObjectInputStream 对象反序列化出来的对象也是同一个对象 。例程9-2 SimpleServerimport java.io.*;import .*;import java.util.*; public class SimpleServer public void send(Object object)throws IOException ServerSocket serverSocket

14、= new ServerSocket(8000); while(true) Socket socket=serverSocket.accept(); OutputStream out=socket.getOutputStream(); ObjectOutputStream oos=new ObjectOutputStream(out); oos.writeObject(object); oos.writeObject(object); oos.close(); socket.close(); 例程9-2 SimpleServerpublic static void main(String ar

15、gs)throws IOException Object object=null; if(args.length0 else if(args.length0 else if(args.length0 Order2 order1=new Order2(“number1“,customer); Order2 order2=new Order2(“number2“,customer); customer.addOrder(order1); customer.addOrder(order2); object=customer; 例程9-2 SimpleServerelse if(args.length0 else if(args.length0 Order4 order1=new

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 中学教育 > 教学课件

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号