序列化、反序列化原理和Protobuf实现机制

65 篇文章 1 订阅 ¥79.90 ¥99.00
本文详细介绍了Java序列化和反序列化的概念、应用场景以及序列化算法步骤。重点讨论了Java内置的序列化机制,并强调了序列化的好处,包括数据持久化和远程通信。接着,文章探讨了实现序列化和反序列化的基本步骤,包括使用ObjectOutputStream和ObjectInputStream。此外,还提到了JSON和谷歌的Protobuf协议。特别针对Protobuf,阐述了其高效率和跨语言特性,以及如何通过.proto文件生成Java代码进行序列化和反序列化的实践过程。最后,文章分析了ProtoBuf的实现机制,指出其字节流紧凑和数据动态伸缩的优势。
摘要由CSDN通过智能技术生成

序列化、反序列化原理和Protobuf实现机制

1 基本概念
1.1 什么是序列化和反序列化

(1)Java序列化是指把Java对象转换为字节序列的过程,而Java反序列化是指把字节序列恢复为Java对象的过程;
(2)序列化:对象序列化的最主要的用处就是在传递和保存对象的时候,保证对象的完整性和可传递性。序列化是把对象转换成有序字节流,以便在网络上传输或者保存在本地文件中。序列化后的字节流保存了Java对象的状态以及相关的描述信息。序列化机制的核心作用就是对象状态的保存与重建。
(3)反序列化:客户端从文件中或网络上获得序列化后的对象字节流后,根据字节流中所保存的对象状态及描述信息,通过反序列化重建对象。
(4)序列化就是把实体对象状态按照一定的格式写入到有序字节流,反序列化就是从有序字节流重建对象,恢复对象状态。
1.2 为什么需要序列化与反序列化
我们知道,当两个进程进行远程通信时,可以相互发送各种类型的数据,包括文本、图片、音频、视频等, 而这些数据都会以二进制序列的形式在网络上传送。
还有,当互联网电商项目并发访问很大的时候,数百万用户产生数百万个session对象,内存可能吃不消

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

学无止路

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值