其中,syntax 关键字表示使用的protobuf的版本,如不指定则默认使用 "proto2";package关键字 表示“包”,生成目标语言文件后对应C++中的namespace命名空间,用于防止不同的消息类型间的命名冲突。 (syntax单词字面含义:句法,句法规则,语构) 然后使用 protobuf编译器(protoc命令)将编写好的 .proto 文件生成 目标语言文件...
如下介绍c语言的protobuf+rpc的开源库protobuf-c和protobuf-c-rpc,其适合于嵌入式分布式场景,利用protobuf协议的可扩展性比较方便进行协议兼容升级,利用rpc接口的网络易用性,不需要再从头到尾实现一遍socket通信、通信接口设计,只需要实现C函数接口设计和开发以及利用proto设计好交互协议即可,并且具备一定的跨编程语言交...
met:No package ‘protobuf’ found 构建protobuf-c其实跟protobuffer几乎没任何区别,也是通过autogen.sh脚本生成configure配置脚本,然后执行make和install。但是需要注意的是protobuf-c在构建的时候不会自动把相关头文件拷贝到/usr/include下,需要手动拷贝。 从https://github.com/protobuf-c/protobuf-c.git克隆下pr...
从中我们知道,这里的protobuf的主要作用是生成了protoc工具,而protoc工具的作用是把.proto文件生成对应的C源、头文件,这个过程是与平台无关的,所以这里我们可以接着用。 而protobuf-c生成了编译需要用到的动态库,此处我们需要编译ARM架构的动态库。即我们本篇笔记需要做的事情是: (1)交叉编译protobuf-c 首先在prot...
demo很简单,组包就是构造一个协议数据结构体,调用pack组包接口往buffer中扔数据;解包正好是反过来,从buffer中拿数据放到结构体里。 此时我们工程的文件有: 交叉编译: arm-linux-gnueabihf-gcc student.c student.pb-c.c-o student-I/home/book/git_clone/protobuf-c/tmp/include-L/home/book/git_clone/proto...
首先在protobuf-c目录下使用make clean命令清除我们之前编译得到的东西: 输入如下命令生成交叉编译的Makefile文件: 左右滑动查看全部代码>>> ./configure --host=arm-linux-gnueabihf CC=/home/book/ToolChain/gcc-arm-linux-gnueabihf-6.2.1/bin/arm-linux-gnueabihf-gcc CXX=/home/book/ToolChain/gcc-arm-linux-...
demo 很简单,组包就是构造一个协议数据结构体,调用 pack 组包接口往 buffer 中扔数据;解包正好是反过来,从 buffer 中拿数据放到结构体里。 此时我们工程的文件有: 交叉编译: 左右滑动查看全部代码>>> arm-linux-gnueabihf-gcc student.c student.pb-c.c -o student -I /home/book/git_clone/protobuf-c/...
首先在protobuf-c目录下使用make clean命令清除我们之前编译得到的东西: 输入如下命令生成交叉编译的Makefile文件: 左右滑动查看全部代码>>> ./configure --host=arm-linux-gnueabihf CC=/home/book/ToolChain/gcc-arm-linux-gnueabihf-6.2.1/bin/arm-linux-gnueabihf-gcc CXX=/home/book/ToolChain/gcc-arm-linux-...
2.1.1 ProtoBuf协议数据结构定义 RPC通信交互的数据在发送前需要用ProtoBuf进行二进制序列化,并且在通信双方收到后要对二进制序列化数据进行反序列化。双方通信时发送的都是固定结构的消息体,比如登录请求消息体(用户名+密码),注册请求消息体(用户id+用户名+消息体)。