IO流的理解第三篇 序列化与反序列化

一、概念:所谓序列化就是将对象转为字节流的过程(把对象写到指定文件中)

                 反序列化则是将字节流转换为对象的过程。(从文件中读取对象)

作用:

1) 把对象的字节序列永久地保存到硬盘上,通常存放在一个文件中;

2) 在网络上传送对象的字节序列。

二、涉及场景

        最常见的是Web服务器中的Session对象,当有 10万用户并发访问,就有可能出现10万个Session对象,内存可能吃不消,于是Web容器就会把一些session先序列化到硬盘中,等要用了,再把保存在硬盘中的对象还原到内存中。

        当两个进程在进行远程通信时,彼此可以发送各种类型的数据。无论是何种类型的数据,都会以二进制序列的形式在网络上传送。发送方需要把这个Java对象转换为字节序列,才能在网络上传送;接收方则需要把字节序列再恢复为Java对象。

三、如何实现

     1, 对象序列化流 java.io.ObjectOutputStream

      构造方法:ObjectOutputStream(OutputStream out) 创建写入指定OutputStream的ObjectOutputStream。

      方法:void writeObject(Object object) 将指定的对象写入ObjectOutputStream。

    2,对象反序列化流java.io.ObjectInputStream

    构造方法:ObjectInputStream(InputStream in) 创建从指定InputStream 读取的ObjectInputStream。

    方法:void ReadObject(Object object) 从ObjectInputStream读取对象

四、注意点

     1、当一个对象要能被序列化,这个对象所属的类必须实现Serializable接口,当实现Serializable接口后jvm会为该类.class文件生成唯一s​e​r​i​a​l​V​e​r​s​i​o​n​U​I​D。当序列化时也会将此ID写入文件。在序列化后,如果后续有改动此文件s​e​r​i​a​l​V​e​r​s​i​o​n​U​I​D也会变,反序列化时则因s​e​r​i​a​l​V​e​r​s​i​o​n​U​I​D不同而报错。定义一个 private static final long s​e​r​i​a​l​V​e​r​s​i​o​n​U​I​D = 2L;可避免。

    2、当一个类的对象被序列化时,某些属性不需要被序列化,可以使用关键字transient修饰。private transient int age;

    3、静态成员不可被序列化(静态成员属于类,是对象的共享数据),序列化与反序列化是针对对象的

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值