文档章节

google proto buf学习

y
 yizhangxyz
发布于 2017/03/28 10:18
字数 221
阅读 17
收藏 0

protobuf是Google开发的一个序列化框架,类似XML,JSON,基于二进制,比传统的XML表示同样一段内容要短小得多。通过protobuf,可以很轻松的调用相关方法来完成业务数据的序列化与反序列化

1.proto文件,google buffer的原型文件。通过protoc.exe --cpp_out生成对应的cpp文件,
通过protoc.exe –I生成对应的二进制文件(.proto文件)。syntax = "proto2";表示协议版本。


2.repeated类型的使用:相当于std的vector。 

message Person {  
  required int32 age = 1;  
  required string name = 2;  
}  
message Family {  
  repeated Person person = 1;  
}  

Family family;  
Person* person;  
  
person = family.add_person();  // 添加一个家庭成员,John  
person->set_age(25);  
person->set_name("John");  
  
person = family.add_person();  // 添加一个家庭成员,Lucy  
person->set_age(23);  
person->set_name("Lucy");  
  
// 显示所有家庭成员  
int size = family.person_size();  
for(int i=0; i<size; i++)   {  
     Person psn = family.person(i);  
     cout << i+1 << ". " << psn.name() << ", 年龄 " << psn.age() << endl;  

© 著作权归作者所有

共有 人打赏支持
上一篇: std学习
下一篇: boost学习
y
粉丝 1
博文 67
码字总数 42366
作品 0
成都
私信 提问
online游戏服务器架构--数据库及事件相关

Online服务器的第三部分就是数据层,send_request_to_db开始了数据层的处理逻辑: int send_request_to_db(int cmd, sprite_t* p, int body_len, const void* body_buf, uint32_t id); 在该......

晨曦之光
2012/04/10
635
0
python处理http请求中的protobuf

一、定义自己的protobuf 这里我定义一个简单的protobuf,用于实现通过http中的protobuf上传一个人的个人信息,以及通过http请求获取服务器上的个人信息。由于本例只是说明protobuf的使用,所...

翼动动空
2016/05/09
803
0
mac 上安装Protobuffer

介绍 Protocol Buffers (ProtocolBuffer/ protobuf )是Google公司开发的一种数据描述语言,类似于XML能够将结构化数据序列化,可用于数据存储、通信协议等方面。现阶段支持C++、JAVA、Pytho...

solate
2016/12/05
118
0
ProtoBuf与Python结合使用初步

ProtoBuf与Python结合使用初步 丛林听雨2016-11-04138 阅读 python Protocol Buffers是 Google 公司开发的一种 数据描述语言 ,类似于 XML 能够将结构化数据 序列化 ,可用于数据存储、 通信...

丛林听雨
2016/11/04
0
0
Linux下的TUN/TAP编程

TUN/TAP虚拟网络设备为用户空间程序提供了网络数据包的发送和接收能力。他既可以当做点对点设备(TUN),也可以当做以太网设备(TAP)。实际上,不仅Linux支持TUN/TAP虚拟网络设备,其他UNI...

慎思
2012/08/01
0
0

没有更多内容

加载失败,请刷新页面

加载更多

Sping之项目中pofile的应用

工程中,我们必须要面对的一件事就是, 开发环境中使用的数据库连接地址等与生产上的不同, 如果上线, 那么我们是否还要手动修改这些地址么, 这样做有很多弊端, 不方便, 这时我们就可以使用spr...

克虏伯
6分钟前
0
0
Linux中安装MySQL

Linux中安装MySQL 一、准备工作 此处准备的操作系统位CentOS 7。 MySQL安装包: MySQL-server-5.6.29-1.linux_glibc2.5.x86_64.rpm MySQL-client-5.6.29-1.linux_glibc2.5.x86_64.rpm 将准备......

星汉
11分钟前
0
0
深入理解Hadoop之HDFS架构

Hadoop分布式文件系统(HDFS)是一种分布式文件系统。它与现有的分布式文件系统有许多相似之处。但是,与其他分布式文件系统的差异是值得我们注意的: HDFS具有高度容错能力,旨在部署在低成...

架构师springboot
15分钟前
0
0
MaxCompute表设计最佳实践

MaxCompute表设计最佳实践 产生大量小文件的操作 MaxCompute表的小文件会影响存储和计算性能,因此我们先介绍下什么样的操作会产生大量小文件,从 而在做表设计的时候考虑避开此类操作。 使用...

阿里云官方博客
15分钟前
0
0
云上领跑,快人一步:华为云抢先发布Redis5.0

12月17日,华为云在DCS2.0的基础上,快人一步,抢先推出了新的Redis 5.0产品,这是一个崭新的突破。目前国内在缓存领域的发展普遍停留在Redis4.0阶段,华为云率先发布了Redis5.0,全面展现了...

中间件小哥
15分钟前
0
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部