《JAVA序列化》PPT课件

《JAVA序列化》PPT课件

ID:39357113

大小:1.03 MB

页数:16页

时间:2019-07-01

《JAVA序列化》PPT课件_第1页
《JAVA序列化》PPT课件_第2页
《JAVA序列化》PPT课件_第3页
《JAVA序列化》PPT课件_第4页
《JAVA序列化》PPT课件_第5页
资源描述:

《《JAVA序列化》PPT课件》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、第九章JAVA序列化本章主要内容9.1序列化概念9.2JAVA中序列化实现9.3序列化机制9.4处理对象流(序列化过程和反序列化过程)9.5定制序列化过程9.6小结9.1序列化概念所谓对象序列化就是将对象的状态转换成字节流,以后可以通过这些值再生成相同状态的对象。这个过程也可以通过网络实现,例如可以先在Windows机器上创建一个对象,对其序列化,然后通过网络发给一台Unix机器,然后在那里准确无误地重新"装配"。像RMI、Socket、JMS、EJB它们中的一种,彼此为什么能够传递Java对象,当然都是对象序列化机制的功劳JAVA中序列化实现JAVA中如何序列

2、化一个对象呢?一个对象能够序列化的前提是实现Serializable接口Serializable接口没有方法,更像是个标记。有了这个标记的Class就能被序列化机制处理。如publicclassSerialTestimplementsSerializable{privatestaticfinallongserialVersionUID=-67292639649740069L;publicbyteversion=100;publicbytecount=0;/**将对象序列化并输出。*ObjectOutputStream能把Object输出成Byte流。*我们将By

3、te流暂时存储到temp.out文件里*/publicstaticvoidmain(String[]args)throwsIOException{FileOutputStreamfos=newFileOutputStream("src/temp.out");ObjectOutputStreamoos=newObjectOutputStream(fos);SerialTesttest=newSerialTest();oos.writeObject(test);oos.flush();oos.close();}}实现Serializable接口将byte流存储到te

4、mp.out文件中序列化机制序列化分为两大部分:序列化和反序列化。序列化是这个过程的第一部分,将数据分解成字节流,以便存储在文件中或在网络上传输。反序列化就是打开字节流并重构对象。对象序列化不仅要将基本数据类型转换成字节表示,有时还要恢复数据。恢复数据要求有恢复数据的对象实例。ObjectOutputStream中的序列化过程与字节流连接,包括对象类型和版本信息。反序列化时,JVM用头信息生成对象实例,然后将对象字节流中的数据复制到对象数据成员中处理对象流(序列化过程和反序列化过程)Java.io包有两个序列化对象的类。ObjectOutputStream负责将

5、对象写入字节流ObjectInputStream从字节流重构对象ObjectOutputStream类扩展DataOutput接口。writeObject()方法是最重要的方法,用于对象序列化。如果对象包含其他对象的引用,则writeObject()方法递归序列化这些对象。每个ObjectOutputStream维护序列化的对象引用表,防止发送同一对象的多个拷贝。由于writeObject()可以序列化整组交叉引用的对象,因此同一ObjectOutputStream实例可能不小心被请求序列化同一对象。这时,进行反引用序列化,而不是再次写入对象字节流。Object

6、OutputStream序列化today'sdate到一个文件中.publicstaticvoidmain(String[]args)throwsIOException{FileOutputStreamfos=newFileOutputStream("src/today'sdate");ObjectOutputStreamoos=newObjectOutputStream(fos);oos.writeObject("Today");oos.writeObject(newDate());oos.flush();oos.close();}对象序列化ObjectInp

7、utStreamObjectInputStream与ObjectOutputStream相似,扩展DataInput接口。ObjectInputStream中的方法镜像DataInputStream中读取Java基本数据类型的公开方法。readObject()方法从字节流中反序列化对象。每次调用readObject()方法都返回流中下一个Object。对象字节流并不传输类的字节码,而是包括类名及其签名。readObject()收到对象时,JVM装入头中指定的类。如果找不到这个类,则readObject()抛出ClassNotFoundException,如果需要

8、传输对象数据和字节码,则

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。