序列化和反序列化(一)——概述

是什么

        将堆内存中Java对象转换为字节序列的过程称为序列化(Serialization),对象转换成字节序列便于将其存储在文件中或在网络上传输;将字节序列恢复为对象的过程称为反序列化(Deserialization)。

       注意:序列化时,只对对象的状态进行序列化,而不管对象的方法;

为什么

序列化与反序列化意义:

        a、通过序列化可以将Java对象信息保存到磁盘文件中,通过反序列化又可以将磁盘文件中的信息恢复为Java对象。比如Tomcat服务器正常关闭时,会将还在生存时间内的session对象保存在SESSIONS.ser(默认值)文件中;Tomcat服务器重启时,会去读取文件并逐一校验其中保存的session是否过期,如过期就销毁session

       b、通过序列化可以将Java对象信息转换为诸如JsonXML等数据格式,便于对象网络传输。

怎么做

       a、创建实现SerializableExternalizable接口的实现类,只有实现SerializableExternalizable接口的类创建的对象才允许被序列化;

b、通过ObjectOutputStream对象的writeObject()方法实现Java对象序列化操作;通过ObjectInputStream对象的readObject() 方法实现Java对象的反序列化操作

发布了327 篇原创文章 · 获赞 571 · 访问量 164万+
展开阅读全文

没有更多推荐了,返回首页

©️2019 CSDN 皮肤主题: 书香水墨 设计师: CSDN官方博客

分享到微信朋友圈

×

扫一扫,手机浏览