【Protobuf速成指南】什么是Protobuf?

news2024/11/25 0:38:55

文章目录

    • 一、序列化和反序列化
      • 1.1 概念
      • 1.2 场景
      • 1.3 如何序列化
    • 二、Protobuf介绍
      • 1. 自身特点
      • 2.使用特点

一、序列化和反序列化

1.1 概念

🎯[总结]:

  • 序列化:把对象转换为字节序列的过程称为对象的序列化。
  • 反序列化:把字节序列恢复为对象的过程称为对象的反序列化。

1.2 场景

🎯[总结]:

  • 存储数据:把的内存中的对象状态保存到⼀个文件中或者存到数据库中时
  • 网络传输:在网络间传输数据时

 我们生活中都有过序列化和反序列化的场景:打电话的时候,我们说的和听到的都是声音信号,而传输过程中信号则是以光电的形式传输的。发送方将声音信号按照一定的协议转为光电信号的过程就是序列化,接收方将光电信号再转化为声音信号,重新还原原始的语音内容的过程就是反序列化

image-20230604170736229
 而在实际上在编程中,序列化和反序列化是将抽象的数据结构或对象转换为字节流,并再次还原回原始数据的过程。

 序列化和反序列化的意义就在于,我们可以以一种通用的方式传输数据。例如在网络世界中,传输数据时我们只需要关注字节流。这省去了我们很多的麻烦,因为不同主机间内存对齐的方式可能不同、变量的大小也可能不同……如果以二进制的方式直接传输结构体对象,上面的问题我们都需要考虑。

 而对于字节流,我们只需要按照一定的协议,一定能将结构体的信息完整正确的读出。例如对于下面这个结构体对象,我们可以设计这样的协议:结构体成员变量间用\3分隔,结构体间用\r\n分隔;一个结构体字节流中,先出现的代表id,后出现的代表name。

 这样,虽然不同平台间的可能存在不同,但是协议规定了成员变量间用 \3 分隔。因此在没有读到 \3 之前,我们都认为这是一个成员变量的一部分;读到 \3 后表示一个完整的成员变量被读取了,此时我们只需要根据协议做字符串的类型转换即可。

struct data{
    // ……
    int id;
    string name;
};

现在我们有如下两个结构体变量需要传输:

data d1(1, "A");
data d2(2, "B")

 根据上面的协议序列化后就变成了这样一段字符串: 1\3A\r\n2\3B\r\n ,接收方收到这段字符串数据后,根据协议就能准确的读取出原来结构体成员的数据了

1.3 如何序列化

 通过上面的例子我们可以看出,序列化反序列化和协议是息息相关的。对于复杂的项目来说,协议设计就不会这么简单了。如果每次序列化和反序列化这种重复但又不可缺少的工作要让程序员来做,那么程序员的效率要大打折扣。

 于是涌现出了一批的工具来帮我们完成序列化和反序列化的工作,例如xml、json以及本系列教程所要重点说明了Protobuf

二、Protobuf介绍

1. 自身特点

首先看看官方文档对于Protobuf的介绍:

  1. ProtocolBuffers是Google的⼀种语言无关、平台无关、可扩展的序列化结构数据的方法,它可用于(数据)通信协议、数据存储等。

  2. ProtocolBuffers类比于XML,是⼀种灵活,高效,自动化机制的结构数据序列化方法,但是比XML更小、更快、更为简单。

  3. 你可以定义数据的结构,然后使用特殊生成的源代码轻松的在各种数据流中使⽤各种语言进行编写和读取结构数据。你甚至可以更新数据结构,而不破坏由旧数据结构编译的已部署程序

总结起来就是

  • 语言无关、平台无关: 即ProtoBuf支持Java、C++、Python等多种语言,支持多个平台
  • 高效: 比XML、JSON更小,更加高效
  • 扩展性好

2.使用特点

ProtoBuf依赖通过Protoc编辑器编译生成的头文件源文件来使用的:

image-20230604182030218

在传统的业务逻辑中,程序员都需要在class中编写下面的内容:

  • 定义一系列属性字段
  • 处理字段的方法(例如get与set)
  • 序列化和反序列化方法

 但是使用Protobuf时,我们只需要完成第一步工作(定义属性字段),Protoc编译器会自动根据属性字段生成对应的处理方法和序列化反序列化方法,我们只需要调用对应的头文件即可。

在这里插入图片描述

下篇博客中将带大家完成Protobuf的环境安装

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/608943.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

MySQL数据库 8.DML操作

目录 ​编辑 🤔前言: 🤔DML介绍: 🤔语法详情: 😀1.插入数据: 特点: 1.给指定字段添加数据: 代码示例: 运行结果: 2.给所有的字段添加数据&…

好的用户体验和性能:现代前端的双赢之路

部分数据来源:ChatGPT 引言 随着 Web 应用程序的复杂度和重要性逐渐上升,前端开发人员已经开始更加注重应用程序的可用性和性能。在这个快速变化的时代,前端开发是日益增长的一个领域。 在当前的前端领域,用户体验和性能是前端开…

解决在谷歌浏览器下载时文件名包含逗号导致页面显示网页不可用问题

项目场景: 自己开发的文件服务项目在使用时测试反馈在下载文件时,文件名包含逗号时下载失败,无法跳转到下载链接页面。 项目使用springboot开发,文件的上传基于SpringMVC的表单文件上传。但是下载时由于需要下载原文件名&#xf…

【IC设计】基于Verilog的8层矩阵乘法设计

文章目录 项目要求基本要求截断要求低位截断高位饱和 参考结果 项目实现实现思路实现代码matrix_multiplier_16.vtb_mm_mlp.v VCS&Verdi综合前仿真dc综合VCS&Verdi综合后仿真不足之处 项目要求 基本要求 输入有9个矩阵,权重矩阵有8个,分别是We…

win11安装open-ssh server

帮助链接: 安装 OpenSSH | Microsoft Learn step1: 本机管理模式的power shell下查询安装状态 Get-WindowsCapability -Online | Where-Object Name -like OpenSSH* Name : OpenSSH.Client~~~~0.0.1.0 State : InstalledName : OpenSSH.Server~~~~0.0.1.0 Stat…

Kafka生产者与消费者api示例

生产者api示例 一个正常的生产逻辑需要具备以下几个步骤 配置生产者参数及创建相应的生产者实例 构建待发送的消息 发送消息 关闭生产者实例 采用默认分区方式将消息散列的发送到各个分区当中 package com.doitedu;import org.apache.kafka.clients.producer.KafkaProduce…

【人工智能】— 线性分类器、感知机、损失函数的选取、最小二乘法分类、模型复杂性和过度拟合、规范化

【人工智能】— 感知机、线性分类器、感知机、感知机、最小二乘法分类、模型复杂性和过度拟合、规范化 Linear predictions 线性预测分类线性分类器感知机感知机学习策略损失函数的选取距离的计算 最小二乘法分类求解最小二乘分类矩阵解法一般线性分类模型复杂性和过度拟合训练…

重估端到端原则

评价技术迭代的旧的定势眼光来自于该技术诞生时。 1970/80/90 年代,相比传输带宽技术,处理器更强。网络协议倾向于字段多,字段小且紧凑,尽可能减少传输量,用 “算法技巧” 等价,如果 TCP 序列号 48 位&…

【iOS】消息传递和消息转发机制

消息传递机制 在OC语言中,调用对象的方法被叫做消息传递。消息有名称和选择子(selector),可以接受参数,还可能有返回值。 在Objective-C中,如果向某对象传递消息,那就会使用动态绑定机制来决定需要调用的方法。在底层…

C++进阶 —— 范围for(C++11新特性)

目录 一,范围for介绍 二,范围for注意事项 一,范围for介绍 范围for(range-based for loop)是C11新引入的特性,可遍历各种序列结构的容器(如数组、vector、list等);每次循…

【QT】Qt ApplicationManager Compositor源码分析

Qt ApplicationManager的Compositor功能分析 根据Qt ApplicationManager官网介绍,它基于Wayland协议实现了Compositor功能。下述为官网介绍。实际上,QtApplicationManager是使用了QtWayland模块来实现Compositor的。Wayland是一套旨在替代XWindow的 Com…

微机实验:第5章——存储器设计

存储器设计 将两片6116所有的存储单元都写入11H。 提示:6116的存储容量为2K*8b,片内地址为0000H-07FFH,两片一起构成F8000H-F8FFFH的内存空间。 仿真调试时可以看到:每片从0000H-07FFH的每个存储单元均显示11H。 CODE SEGMENTASSUME CS:C…

4-4 哈夫曼编码

博主简介:一个爱打游戏的计算机专业学生博主主页: 夏驰和徐策所属专栏:算法设计与分析 1.什么是哈夫曼编码? 哈夫曼编码(Huffman coding)是一种用于数据压缩的无损编码方法。它是由David A. Huffman在1952…

STM32F4_软件模拟SPI

目录 1. 硬件连接 2. SPI通讯协议 3. W25Q64 简介 4. 程序详解 4.1 main.c 4.2 SPI.c 4.3 SPI.h 4.4 W25Q128.c 4.5 W25Q128.h 4.6 OLED.c 4.7 OLED.h 4.8 OLED_Font.h 5. 实验结果 我们都知道,SPI 和 IIC 一样,都可以通过硬件方式和软件方…

JSON基础(待补充)

一、JSON初识 1.1基础认识 JSON是一种轻量级的数据交换格式,它基于JavaScript语言的对象表示法,可以在多种语言之间进行数据交换。JSON的基本数据类型有数值、字符串、布尔值、数组、对象和空值。JSON的格式简洁易读,也易于解析和处理。JSON…

【数据结构】由完全二叉树引申出的堆的实现

【数据结构】由完全二叉树引申出的堆的实现 一、什么是堆二、目标三、实现1、初始化工作2、堆的插入(堆的创建)2.1、向上调整建堆2.1.1、向上调整算法原理解析2.1.2、代码实现 2.2、向下调整建堆2.2.1、向下调整算法原理解析2.2.2、代码实现 2.3、“向上”和“向下”复杂度的差…

初识网络安全

目录 HTML前置基础知识 1、id和class区别: 2、一些常用的属性: 3、HTML字符编码和实体编码 4、URL介绍 网址的组成部分: TTL值 DNS工作原理和资源记录及其种类: 5、正确区分“加密”和“签名” 6、状态码 1xx &#xf…

如何安装pycharm

PyCharm是JetBrains公司推出的一款Python集成开发环境(IDE),可以提供高效的Python代码编写、调试和测试。以下是一些PyCharm的主要功能: 代码智能提示和自动补全功能;支持调试和测试Python代码;完整的Pyth…

基于Springboot+Vue的幼儿园管理系统设计与实现

博主介绍: 大家好,我是一名在Java圈混迹十余年的程序员,精通Java编程语言,同时也熟练掌握微信小程序、Python和Android等技术,能够为大家提供全方位的技术支持和交流。 我擅长在JavaWeb、SSH、SSM、SpringBoot等框架下…

汽车相关知识及术语

1 汽车构造与制造流程 1.1 汽车构造 汽车可以分为四大部分 车身: 骨架、车身钣金件以及座椅、仪表、天窗、车外后视镜等车身附件 动力系统: 发动机和变速器 底盘: 传动系统、悬架系统、转向系统、制动系统和车轮轮胎 电气电子系统&#…