ProtoBuffer 简单例子

简介:

最近学了一下protobuf,写了一个简单的例子,如下:

person.proto文件

[cpp]  view plain  copy
 
  1. message Person{  
  2.     required string name = 1;  
  3.     required int32 age = 2;  
  4.     optional string email = 3;  
  5.     enum PhoneType{   
  6.         MOBILE = 1;  
  7.         HOME = 2;  
  8.         WORK = 3;  
  9.     }  
  10.     message Phone{  
  11.         required int32 id = 1;  
  12.         optional PhoneType type = 2 [default = HOME];  
  13.     }  
  14.     repeated string phoneNum = 4;  //对应于cpp的vector  
  15. }  
安装好protoc以后,执行protoc person.proto --cpp_out=. 生成 person.pb.h和person.pb.cpp

写文件(write_person.cpp):

[cpp]  view plain  copy
 
  1. #include <iostream>  
  2. #include "person.pb.h"  
  3. #include <fstream>  
  4. #include <string>  
  5.   
  6. using namespace std;  
  7.   
  8. int main(){  
  9.     string buffer;  
  10.     Person person;  
  11.     person.set_name("chemical");  
  12.     person.set_age(29);  
  13.     person.set_email("ygliang2009@gmail.com");  
  14.     person.add_phonenum("abc");  
  15.     person.add_phonenum("def");  
  16.     fstream output("myfile",ios::out|ios::binary);  
  17.     person.SerializeToString(&buffer); //用这个方法,通常不用SerializeToOstream  
  18.     output.write(buffer.c_str(),buffer.size());  
  19.     return 0;  
  20. }  
编译时要把生成的cpp和源文件一起编译,如下:g++ write_person.cpp person.pb.cpp -o write_person -I your_proto_include_path -L your_proto_lib_path -lprotoc -lprotobuf运行时记得要加上LD_LIBRARY_PATH=your_proto_lib_path

读文件(read_person.cpp):

[cpp]  view plain  copy
 
  1. #include <iostream>  
  2. #include "person.pb.h"  
  3. #include <fstream>  
  4. #include <string>  
  5.   
  6. using namespace std;  
  7.   
  8. int main(){  
  9.     Person *person = new Person;  
  10.     char buffer[BUFSIZ];  
  11.     fstream input("myfile",ios::in|ios::binary);  
  12.     input.read(buffer,sizeof(Person));  
  13.     person->ParseFromString(buffer);  //用这个方法,通常不用ParseFromString  
  14.     cout << person->name() << person->phonenum(0) << endl;  
  15.     return 0;  
  16. }  

编译运行方法同上:g++ read_person.cpp person.pb.cpp -o read_person -I your_proto_include_path -L your_proto_lib_path -lprotoc -lprotobuf

本文转自博客园知识天地的博客,原文链接:ProtoBuffer 简单例子,如需转载请自行联系原博主。


相关文章
|
编解码 Java 编译器
【Protobuf】Protobuf中的Message语法规范
在Message中定义一个或者多个字段,FieldType是字段的数据类型,可以是基本类型(如int32、string、bool等)或其他定义的Message类型。fieldName是字段的名称,可以根据需求自定义。fieldNumber是字段的唯一标识号,用于在消息的二进制编码中标识字段。
395 0
|
3月前
|
JSON Go 数据格式
Golang语言结构体链式编程与JSON序列化
这篇文章是关于Go语言中结构体链式编程与JSON序列化的教程,详细介绍了JSON格式的基本概念、结构体的序列化与反序列化、结构体标签的使用以及如何实现链式编程。
45 4
|
6月前
|
开发工具 git
protobuf的复杂结构
protobuf的复杂结构
85 1
|
7月前
|
Java 编译器 Go
Protobuf3语法笔记
Protobuf3语法笔记
98 0
|
7月前
|
存储 Java Go
|
C++ 容器
使用protobuf的简单流程记录、编译protobuf时遇到的坑 以及 链接protobuf的坑
使用protobuf的简单流程记录、编译protobuf时遇到的坑 以及 链接protobuf的坑
331 0
|
XML JSON Java
Protobuf 语法详解
Protobuf 语法详解
213 0
|
Dubbo 算法 安全
Java序列化案例demo(包含Kryo、JDK原生、Protobuf、ProtoStuff以及hessian)(二)
Java序列化案例demo(包含Kryo、JDK原生、Protobuf、ProtoStuff以及hessian)(二)
Java序列化案例demo(包含Kryo、JDK原生、Protobuf、ProtoStuff以及hessian)(二)
|
SQL 存储 Java
Java序列化案例demo(包含Kryo、JDK原生、Protobuf、ProtoStuff以及hessian)(一)
Java序列化案例demo(包含Kryo、JDK原生、Protobuf、ProtoStuff以及hessian)(一)
Java序列化案例demo(包含Kryo、JDK原生、Protobuf、ProtoStuff以及hessian)(一)
|
XML 数据格式 C++
protobuf C++ 使用示例
1、在.proto文件中定义消息格式 2、使用protobuf编译器 3、使用c++ api来读写消息   0、为何使用protobuf?   1、原始内存数据结构,可以以二进制方式sent/saved.这种方式需要相同的内存布局和字节序。
8381 0