Java学习之序列化

我们都站在巨人的肩膀上


1.序列化:

  • 以特定的方式对类实例的瞬时状态进行编码保存的一种操作。
  • 将一个对象的状态(各个属性量)保存起来,然后在适当的时候再获得。
  • 将数据分解成字节流,以便存储在文件中或在网络上传输

2.反序列化:

  • 打开字节流并重构对象。
  • 对象序列化不仅要将基本数据类型转换成字节表示,有时还要恢复数据。
  • 恢复数据要求有恢复数据的对象实例

3.序列化特点:

  • 如果某个类能够被序列化,其子类也可以被序列化
  • 声明为statictransient类型的成员数据不能被序列化重点内容。因为static代表类的状态transient代表对象的临时数据

4.对象序列化:

  • 在没有序列化前,每个保存在(Heap)中的对象都有相应的状态(state),即实例变量(instance ariable)
  • 可以存到文件中,又可以从文件中读取出来,在堆中创建原来的对象
  • 保存的时候不仅仅保存实例变量的值JVM也要保存一些信息,比如类的类型等方便将来恢复原来的对象

5.使用场景:

  • 对象序列化可以实现分布式对象。主要应用例如:RMI要利用对象序列化运行远程主机上的服务,就像在本地机上运行对象时一样。
  • java对象序列化不仅保留一个对象的数据,而且递归保存对象引用的每个对象的数据。可以将整个对象层次写入字节流中,可以保存在文件中或在网络连接上传递。利用对象序列化可以进行对象的”深复制”,即复制对象本身及引用的对象本身。序列化一个对象可能得到整个对象序列。
  • 当你想把的内存中的对象状态保存到一个文件中或者数据库中时候。
  • 保存这个状态的作用主要用于不同jvm之间进行类实例间的共享

6.为什么要使用serialVersionUID

  • 对于实现了Serializable接口的类,可以将其序列化输出至磁盘文件中,同时会将其serialVersionUID输出到文件中。
  • 然后有需要使用时,再从磁盘将对象内容及serialVersionUID读入内容中的某个对象。
  • 将磁盘内容读入对象时,需要进行强制类型转换
  • 此时,将对比从磁盘读入的Serializable与对象所属类的Serializable,若二者一致,则转换成功。若二者不一致,则转换失败,并抛出InvalidClassException。

7.serialVersionUID一种就是1L,一种是生成一个很大的数,这两种有什么区别呢?

  1. 手工递增版本号。1->2->3…..
  2. 根据类的结构产生的hash值。增减一个属性、方法等,都可能导致这个值产生变化。我想这种方式适用于这样的场景:开发者认为每次修改类后就需要生成新的版本号,不想向下兼容,操作就是删除原有serialVesionUid声明语句,再自动生成一下。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值