RabbitMQ的学习和模拟实现|Protobuf的介绍和简单使用

protbuf的介绍和简单使用

项目仓库:https://github.com/ffengc/HareMQ

protobuf的安装:README-cn.md#环境配置

基于Protobuf的一个小项目:基于protobuf和httplib的在线通讯录项目框架|Protobuf应用小项目

protobuf是什么

ProtoBuf(全称Protocol Buffer)是数据结构序列化和反序列化框架,它具有以下特点:

  • 语言无关、平台无关:即 ProtoBuf支持 Java、C++、Python 等多种语言,支持多个平台

  • 高效:即比 XML 更小、更快、更为简单

  • 扩展性、兼容性好:你可以更新数据结构,而不影响和破坏原有的旧程序

  • 编写.proto文件,目的是为了定义结构对象(message)及属性内容

  • 使用protoc编译器编译.proto 文件,生成一系列接口代码,存放在新生成头文件和源文件中

  • 依赖生成的接口,将编译生成的头文件包含进我们的代码中,实现对.proto文件中定义的字段进行设置和获取,和对 message 对象进行序列化和反序列化。

快速上手

contacts.proto定义如下。

proto 复制代码
syntax = "proto3";  // 声明语法版本
package contacts;   // 声明命名空间

// 结构化对象的描述
message contact {
    // 各个字段描述
    /* 字段类型 字段名 = 字段唯一编号 */
    uint64 sn = 1;
    string name = 2;
    float score = 3;
};

定义完成proto文件之后,就要让proto给我们生成对应的.h.cc了。

sh 复制代码
protoc  --cpp_out=. contacts.proto

这样就生成成功了。

cpp 复制代码
namespace contacts {
PROTOBUF_CONSTEXPR contact::contact(

这里的命名空间就是我们确定的package的名字。

那么如何调用和使用呢?

注意,使用的时候需要链接上去。

makefile

makefile 复制代码
test: main.cc contacts.pb.cc
	g++ -o $@ $^ -lprotobuf -std=c++11
.PHONY:clean
clean:
	rm -f test

main.cc

cpp 复制代码
int main() {
    contacts::contact conn;
    conn.set_sn(10001);
    conn.set_name("Sam");
    conn.set_score(60.5);

    std::string str = conn.SerializeAsString();
    // conn.SerializeToString(&str); // 一样的
    contacts::contact stu;
    bool ret = stu.ParseFromString(str);
    if (ret == false) // 反序列化失败
        assert(false);
    std::cout << stu.sn() << " " << stu.name() << " " << stu.score() << std::endl;
    return 0;
}

这就是一个基本的使用。

相关推荐
dashizhi20157 分钟前
服务器如何记录共享文件访问日志、查看用户访问共享文件的行为日志?
运维·服务器
tongxh42310 分钟前
自己编译RustDesk,并将自建ID服务器和key信息写入客户端
运维·服务器
FirstFrost --sy11 分钟前
仿mudou库one thread one loop式并发服务器实现
运维·服务器·开发语言·c++
不知名。。。。。。。。12 分钟前
仿muduo库实现高并发服务器--定时器模块的整合
linux·运维·服务器
勿芮介12 分钟前
【大模型应用】在window/linux上卸载OpenClaw
java·服务器·前端
wanhengidc15 分钟前
裸金属服务器与普通服务器的区别
运维·服务器·网络·游戏·智能手机
野犬寒鸦25 分钟前
面试常问:TCP相关(中级篇)问题原因即解决方案
服务器·网络·后端·面试
虾..36 分钟前
Linux 基于TCP实现服务端客户端通信(多进程/多线程版)
java·服务器·tcp/ip
报错小能手1 小时前
nginx集群聊天室(五)nginx配置tcp服务器负载均衡
服务器·tcp/ip·nginx
报错小能手1 小时前
如何手撕集群聊天室项目?
linux·服务器