[序列化协议] --- 简介

简介: [序列化协议] --- 简介

1. 为什么需要序列化和反序列化协议

我们要传输这样一个对象,里面的变量有些是数组形式(languages),有些又还是对象(phone),有些还是数组对象(books)。

name: 姓名, 比如darren
age: 年龄,比如80
languages: 熟悉的编程语言, 普通数组方式,比如["C++", "Linux"],
phone: 电话号码,是嵌套的对象,包含number和type, 比如"number":   "18570368134",
        "type": "home
books: 对象数组方式,可以包含多本书信息, 每本书包含name和price属性。
vip: 是否为vip, 比如true
address: 地址, 比如"yageguoji"

此时我们要将对象从客户端传输到服务器,那应该怎么传输,定义一个person对象,在描述完起成员变量将这个对象占用的内存发送给服务器?比如:

//简单伪代码
Person p1;
封装p1;
然后send(&p1, sizeof(p1).)

这样肯定不行的。比如 languages可能是"C",也可能是是"C++",“Linux”,此时我们sizeof(p1)是固定还是不固定?假如不固定那服务器怎么解析出一个Person来?

既然不能直接传对象,那怎么办?这时候序列化协议就发挥作用了。

2. 序列化和反序列化基础

  • 序列化(serialization)就是将对象序列化为二进制形式(字节数组),一般也将序列化称为编码(Encode),主要用于网络传输、数据持久化等;
  • 反序列化(deserialization)则是将从网络、磁盘等读取的字节数组还原成原始对象,以便后续业务的进行,一般也将反序列化称为解码(Decode),主要用于网络传输对象的解码,以便完成远程调用。
    序列化:把对象转换为字节序列的过程称为对象的序列化。
    反序列化:把字节序列恢复为对象的过程称为对象的反序列化。

3. 什么情况需要序列化

  • 当你想把的内存中的对象状态保存到一个文件中或者数据库中时候;
  • 当你想用套接字在网络上传送对象的时候。

4. 主流序列化协议:xml, json, protobuf

|xml| 通用| 重量级| 文本格式|

|json|通用| 轻量级| 文本格式|

|prottobuf |独立 |轻量级|二进制|

- 通用:协议是标准的,不同的第三方软件都可以相互进行序列化和反序列化,比如使用cjson序列化后的数据,可以使用jsoncpp反序列化。

- 独立:标准是私有的,比如protocol buffer协议,目前只有Google自家支持。

- 文本格式:可以看出内容的具体文字含义

- 二进制格式:纯数值的数据,可读性不强。比如protobuf序列化后的数据。

速度测试和序列化后数据大小对比

测试10万次序列化

测试10万次反序列化

参看链接:

https://zhuanlan.zhihu.com/p/91313277

https://blog.csdn.net/u014043213/article/details/80336805

目录
相关文章
|
6月前
|
XML 存储 JSON
【面试题精讲】序列化协议对应于 TCP/IP 4 层模型的哪一层?
【面试题精讲】序列化协议对应于 TCP/IP 4 层模型的哪一层?
|
6月前
|
XML JSON JavaScript
【面试题精讲】常见序列化协议有哪些?
【面试题精讲】常见序列化协议有哪些?
|
2月前
|
C++
[序列化协议] --- protobuf
[序列化协议] --- protobuf
23 0
|
2月前
|
JSON 数据格式 C++
[序列化协议] --- JSON
[序列化协议] --- JSON
31 0
|
2月前
|
XML 存储 API
[序列化协议] --- XML
[序列化协议] --- XML
29 0
|
4月前
|
存储 JSON 编解码
IM通讯协议专题学习(十):初识 Thrift 序列化协议
本文将带你一起初步认识Thrift的序列化协议,包括Binary协议、Compact协议(类似于Protobuf)、JSON协议,希望能为你的通信协议格式选型带来参考。
61 1
|
7月前
|
存储 Dubbo Java
dubbo 源码 v2.7 分析:通信过程及序列化协议
前面我们介绍了dubbo的核心机制,今天将开始分析远程调用流程。毕竟,作为一个rpc框架,远程调用是理论的核心内容。通过对dubbo相关实现的探究,深入了解rpc原理及可能的问题。
129 0
H8
|
8月前
|
安全 网络协议 Java
跨语言的艺术:Weblogic 序列化漏洞和 IIOP 协议
Weblogic序列化漏洞主要依赖于T3和IIOP协议,在通信交互方面存在诸多问题,如跨语言、网络传输等,给漏洞检测和利用带来诸多不便。在WhiteHat Labs的理念中,漏洞检测和利用是一项创造性的工作,应该以最简洁高效的方式实现,以保证漏洞的跨平台性和实用性。因此,我们实现了跨语言的IIOP协议通信方案来解决序列化漏洞问题。
H8
153 1
|
8月前
|
JSON 网络协议 数据格式
协议,序列化,反序列化,Json
协议,序列化,反序列化,Json
57 0
|
Dubbo Java 应用服务中间件
Dubbo3实践:基于 IDL 的 Triple 协议 Pojo 序列化兼容模式
这篇教程会通过从零构建一个简单的工程来演示如何基于 POJO 方式使用 Dubbo Triple, 在应用不改变已有接口定义的同时升级到 Triple 协议。**此模式下 Triple 使用方式与 Dubbo 协议一样。** 具体用例可以参考:[dubbo-samples-triple/pojo](https://github.com/apache/dubbo-samples/tree/mast
308 0

热门文章

最新文章