Protobuf总结

1:Protocol Buffer简介
Protocol Buffer(PB)是一种轻便高效的结构化数据存储格式,可以用于结构化数据串行化,或者说序列化。可用于通讯软件中与语言无关、平台无关、可扩展的序列化结构数据格式。目前提供了 C++、Java、Python,C#,lua 五种语言的 API。

2:Protocol Buffer优点
支持多种语言;使用简单;具有“向后”兼容性;pb不管是处理时间上,还是空间占用上都优于现有的其他序列化方式

3:下载pb源代码:我用的是protobuf-2.6.1
下载完毕后打开protobuf.sln,
打开protobuf.sln
对protoc进行编译
这里写图片描述
编译成功后打开Dedug目录,会看到生成了libprotoc.lib和protoc.exe。
4:编写proto协议
将protoc.exe拷贝出来,建立两个文件夹,
这里写图片描述
在src中定义消息
这里写图片描述
在test.proto中定义协议 (之后会介绍)

message test
{
    required int32 id=1;
   required string name=2;
}

5:生成Pb类
接下来我们编写一个批处理文件gen.bat
这里写图片描述
cd E:\proto
protoc.exe -I=./src –cpp_out=./dst ./src/test.proto
运行gen.bat后,会在dst文件夹中生成test.pb.h与test.pb.cc
6:在项目中引用Pb类
我们新建一个项目,将test.pb.h与test.pb.cc添加进来。
c/c++->常规->附加包含目录->E:\protobuf-2.6.1\testProto\src;
c/c++->常规->附加包含目录->E:\protobuf-2.6.1\src
链接器->常规->附加库目录->E:\protobuf-2.6.1\vsprojects\Debug
链接器->输入->附加依赖项->libprotobuf.lib
7:使用PB序列化类和反序列化PB类对象

#include "test.pb.h"
#include <iostream>
using namespace std;
void main()
{
    test l;
    l.set_id(100);
    l.set_name("asdfgfg");
    const string s = l.SerializeAsString();
    test l1;
    l1.ParseFromString(s);
    cout << l1.id() << endl;
    cout << l1.name() << endl;
    getchar();
}

“`
结果输出:
这里写图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

程序员的资料库

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值