序列化和反序列化

数据在网络中传输需要按照一定的规范组成。这些规定的规范有json,xml,protobuf。

序列化---反序列化

链接

对象转为二进制流和二进制流转为对象的过程。

JSON、XML 和 protobuf

JSON、XML 和 Protocol Buffers(protobuf)是三种常见的数据表现格式。它们的共同目的是在不同的应用程序和平台之间传输数据,而无需知道底层数据结构或编程语言细节。

以下是每种格式的简要描述:

1. JSON(JavaScript Object Notation):是一种轻量级的数据交换格式。它是基于 JavaScript 对象语法,并以文本格式存储数据。JSON 是平台无关的,易于解析和生成,可被普遍支持。由于其简单、快速和安全,JSON 已成为 Web 开发中最流行的数据交换格式。
2. XML(eXtensible Markup Language):与 JSON 类似,XML 也是一种可读性高,轻量级的数据交换格式。XML 是基于标签结构,并以文本格式存储数据。XML 具有严格的结构和丰富的元数据,可用于描述复杂的数据和多级场景,并具有广泛的应用。
3. Protocol Buffers:是 Google 研发的一种高效的二进制数据交换格式。由于其高效的编解码和紧凑的数据表示,Protocol Buffers 已成为一种流行的网络通信协议和数据交换格式。 它是强类型的,并具有自描述、可扩展、跨平台和反向兼容等优点。
 

protobuf相比于xml和json的优缺点

指标 protobuf JSON XML
序列化速度 ⚡️ 极快 (比JSON快3-10倍) 中等
反序列化速度 ⚡️ 极快 中等
数据大小 🔥 极小 (比JSON小3-5倍) 中等 大 (冗余标签)
CPU占用 中等

JSON

json教程

json语法:

一个{}就是一个json对象。

parse解析时,就会将解析出来的一个{}json对象赋值给一个js对象变量;

比如:

//json对象
 { "name":"runoob", "alexa":10000, "site":null }

//js对象
var myObj;
myObj = { "name":"runoob", "alexa":10000, "site":null };

js对象和变量

//将一个json字符串赋给一个js变量
var person = '{firstName:"John", lastName:"Doe", age:50, eyeColor:"blue"}';

//建立一个对象
var person = {firstName:"John", lastName:"Doe", age:50, eyeColor:"blue"};

json---parse

var data='{ "name":"runoob", "alexa":10000, "site":"www.runoob.com" }';
var obj = JSON.parse(data);

/*
obj={ "name":"runoob", "alexa":10000, "site":"www.runoob.com" };
*/

箭头函数

链接

function foo() {
	let bar = () => {
		console.log(arguments.length);
	}
	bar(); 
}
foo(5, 5, 5);  // 3


bar是函数对象,通过函数对象+()调用箭头函数。

js的函数对象就像c++的lambda表达式。

json序列化和反序列化

nlohmann库

xml

json和xml比较

json---键值对;

xml---标签;

Logo

魔乐社区(Modelers.cn) 是一个中立、公益的人工智能社区,提供人工智能工具、模型、数据的托管、展示与应用协同服务,为人工智能开发及爱好者搭建开放的学习交流平台。社区通过理事会方式运作,由全产业链共同建设、共同运营、共同享有,推动国产AI生态繁荣发展。

更多推荐