资源预览内容
第1页 / 共41页
第2页 / 共41页
第3页 / 共41页
第4页 / 共41页
第5页 / 共41页
第6页 / 共41页
第7页 / 共41页
第8页 / 共41页
第9页 / 共41页
第10页 / 共41页
亲,该文档总共41页,到这儿已超出免费预览范围,如果喜欢就下载吧!
资源描述
对象的序列化与反序列化主要内容概述 当两个进程进行远程通信时,彼此可以发送各 种类型的数据,包括文本图片音频视频等,都 会以二进制序列的形式在网络上传送. 当两个java进程进行通信时,一个进程能否把 一个java对象发送给另一个进程呢?答案是肯定的!概述 如何才能做到呢 1)发送方需要把这个java对象转换为字节序列 ,才能在网上传送 2)接收方需要把字节序列再恢复为java对象. 把java对象转换为字节序列的过程称为对象 的序列化,. 把字节序列恢复为java对象的过程称为对象 的反序列化.序列化与反序列化对象序列化两种用途 把对象的字节序列永久的保存到硬盘上, 通常存放在一个文件中. 在网络上传送对象的字节序列.主机1主机2文件网络传输存储到文件9.1.jdk类库中的序列化API 如何才能做到呢 1)发送方需要把这个java对象转换为字节序列 ,才能在网上传送 2)接收方需要把字节序列再恢复为java对象. 把java对象转换为字节序列的过程称为对象 的序列化,. 把字节序列恢复为java对象的过程称为对象 的反序列化.序列化与反序列化9.1jdk类库中的序列化API java.io.ObjectOutputStream:代表对象输出流 它的writeObject(Object obj)方法可对参数指定的obj对 象进行序列化,把得到的字节序列写到一个目标输 出流中。 Java.io.ObjectInputStream代表对象输入流, 它的readObject()方法从一个源输入流中读取字节, 再把它们反序列化成一个对象,并将其返回。9.1jdk类库中的序列化API 哪些类可以被序列化呢? 只有实现了Serializable或Externalizable接口的类的对 象才能被序列化,否则ObjectOutputStream的 writeObject(Object obj)方法会抛出IOException。 实现了Serializable或Externalizable接口的类也称为可 序列化类。 Externalizable接口继承Serializable接口,实现 Externalizable接口的类完全由自身来控制序列化的行 为。而仅实现Serializable接口的类可以采用默认的 序列化方式。 Jdk的部分类 如StringDate等都实现了Serializable接口9.1jdk类库中的序列化API 假定一个Customer类,它的对象需要序列化。 可以 有以下三种方式进行 如果customer类仅仅实现了Serializable接口的类,那 么会按照以下方式进行序列化和反序列化: ObjectOutputStream采用默认的序列化方式,对 Customer对象的非transient的实例变量进行序列化。 ObjectInputStream采用默认的反序列化方式,对 customer对象的非transient的实例变量进行反序列化 。9.1jdk类库中的序列化API2. 如果customer类仅仅实现了Serializable接口, 并且还定义了readObject(ObjectInputStream in)和 writeObject(ObjectOutputStream out),那么会按照 以下方式进行序列化和反序列化: ObjectOutputStream会调用Customer对象的 writeObject(ObjectOutputStream out)方法进行序 列化。 ObjectInputStream会调用Customer对象的 readObject(ObjectInputStream in)方法进行反序列 化。9.1jdk类库中的序列化API3. 如果customer类实现了Externalizable接口,那 么Customer类必须实现readExternal(ObjectInput in)和writeExternal(ObjectOutput out)方法,那么 会按照以下方式进行序列化和反序列化: ObjectOutputStream会调用Customer对象的 writeExternal(ObjectOutput out)方法进行序列化 。 ObjectInputStream会调用Customer对象的 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 Date();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.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“,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); System.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.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 该服务器从命令行读取用户指定的类名, 创建该类的一个对象,然后向客户端两次 发送这个对象。 结果表明:按照默认方式序列化时,如果 有一个ObjectOutputStream对象多次序列化 同一个对象,那么有一个ObjectInputStream 对象反序列化出来的对象也是同一个对象 。例程9-2 SimpleServerimport java.io.*;import java.net.*;import java.util.*; public class SimpleServer public void send(Object object)throws IOException ServerSocket serverSocket = 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 args)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
收藏 下载该资源
网站客服QQ:2055934822
金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号