Java序列化

  • Java 提供了一种对象序列化的机制,该机制中,一个对象可以被表示为一个字节序列,该字节序列包括该对象的数据、有关对象的类型的信息和存储在对象中数据的类型。

  • 将序列化对象写入文件之后,可以从文件中读取出来,并且对它进行反序列化,也就是说,对象的类型信息、对象的数据,还有对象中的数据类型可以用来在内存中新建对象。

  • 整个过程都是 Java 虚拟机(JVM)独立的,也就是说,在一个平台上序列化的对象可以在另一个完全不同的平台上反序列化该对象。

  • 一个类的对象要想序列化成功,必须满足两个条件:

    该类必须实现 java.io.Serializable 接口或Externalizable接口
    该类的所有属性必须是可序列化的?。如果有一个属性不是可序列化的,则该属性必须注明是短暂的。

  • 使用序列化与反序列化,一是可以实现数据的持久化,把数据永久地保存到硬盘上(通常存放在文件里);二是有助于对象数据的远程通信。

    当两个进程进行远程通信时,可以相互发送各种类型的数据,包括文本、图片、音频、视频等,而这些数据都会以二进制序列的形式在网络上传送。当两个Java进程进行通信时,发送方需要把这个Java对象转换为字节序列,然后在网络上传送;另一方面,接收方需要从字节序列中恢复出Java对象。

  • JDK类库中序列化API

    java.io.ObjectOutputStream:表示对象输出流
    它的writeObject(Object obj)方法可以对参数指定的obj对象进行序列化,把得到的字节序列写到一个目标输出流中。

    java.io.ObjectInputStream:表示对象输入流
    它的readObject()方法源输入流中读取字节序列,再把它们反序列化成为一个对象,并将其返回。

【参考文档】https://www.nowcoder.com/tutorial/10001/11daa075ab024a63b23365ec04a6f404

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值