java的序列化

来源:互联网 发布:linux 查看系统调用 编辑:程序博客网 时间:2024/04/30 07:08

什么叫序列化?

序列化是将对象状态转换为可保持或传输的格式的过程。就是将一个对象的状态(各个属性量)保存起来,然后在适当的时候再获得。

序列化分为两大部分:序列化和反序列化。序列化是这个过程的第一部分,将数据分解成字节流,以便存储在文件中或在网络上传输。反序列化就是打开字节流并重构对象。对象序列化不仅要将基本数据类型转换成字节表示,有时还要恢复数据。恢复数据要求有恢复数据的对象实例

 

 

序列化的目的?

以某种存储形式使自定义对象持久化。

 

将对象从一个地方传递到另一个地方。

 

把内存中的对象状态保存到一个文件中或者数据库中

 

用套接字在网络上传送对象

 

通过RMI传输对象

 

对象序列化可以实现分布式对象。主要应用例如:RMI要利用对象序列化运行远程主机上的服务,就像在本地机上运行对象时一样。

 

java对象序列化不仅保留一个对象的数据,而且递归保存对象引用的每个对象的数据。可以将整个对象层次写入字节流中,可以保存在文件中或在网络连接上传递。利用对象序列化可以进行对象的"深复制",即复制对象本身及引用的对象本身。序列化一个对象可能得到整个对象序列。

 

socket编程中比较常用,当消息从一台主机经过服务器传输到另一台电脑时,就需要Serialize一下

 

 

 

为什么要使用序列化?

举个例子,你编写了一款游戏,保存记录时把所有状态一一保存非常麻烦,这时就可以使用Serializable(序列化接口),它的作用是可以将一个对象实例序列化,序列化后你可以选择将它保存在你需要的位置。相对的,读取后生成的对象所有属性(除了设置为瞬时值的属性)将和原对象的属性相同(只是内存地址不同)。这样可以方便的将一个java对象写入到磁盘中,保存该对象的所有状态!值得注意的是序列化的对象中包含的属性和其他对象都需要实现序列化接口,不然无法正常序列化!在hibernate里,并非所有的实体类必须实现序列化接口,因为在hibernate中我们通常是将基本类型的数值映射为数据库中的字段。而基础类型都实现了序列化接口(String也实现了)。所以,只有在想将一个对象完整存进数据库(存储为二进制码),而不是将对象的属性分别存进数据库,读取时再重新构建的话,就可以不用实现序列化接口。