protobuf 简单入门

1. 概述

  protobuf(Protocol Buffers )是一种轻便高效的结构化数据存储格式,可以用于结构化数据串行化,或者说序列化。它很适合做数据存储或 RPC 数据交换格式。可用于通讯协议、数据存储等领域的语言无关、平台无关、可扩展的序列化结构数据格式。目前提供了 C++、Java、Python 三种语言的 API。

  特点:

  

  • 结构数据串行化,灵活、高效、自动。
  • 相对XML,更小、更快、更简单。
  • 自定义数据结构。
  • 动态更新数据结构。

2. 安装protobuf

  首先,可以从github protobuf工程获取最新版本的源码。然后安装上面的README教程进行安装。大致过程如下:

  

  (1). 运行autogen.sh,生产configure脚本。此过程会自动下载gmock文件,运行autorun、autoconf等。

  

  (2). 编译安装protobuf。

  

$ ./configure

$ make

$ make check

$sudo make install

  默认情况下,程序会安装到/usr/local/目录,但是有些平台上/usr/local/lib并不在LD_LIBRARY_PATH的环境变量中。我们可以通过以下语句配置程序的安装目录。

./configure –prefix=/usr


3. 使用protobuf

3.1 编写接口文件(.proto)

  .proto文件类似于c/c++中的数据定义,这里以test.proto为例:

  

 message TestMsg
{
     required int32 id=1;
     required string describe=2;
     optional string opt=3;
}

  上面定义了一个消息,有三个成员,必须有的int类型的id,string类型的describe和可选的string类型的opt。最上面也可以加上包名package pkg_name

3.2 编译.proto文件

  用 Protobuf 编译器将该文件编译成目标语言,这里使用c++。

protoc -I=$SRC_DIR –cpp_out=$DST_DIR $SRC_DIR/test.proto

  $SRC_DIR是目标路径,–cpp_out输出c++语言版本文件。这里会生成两个文件test.pb.h和test.pb.cc。生产的头文件中定义了一个TestMsg的类,后面会有对它的一系列序列化操作。

3.3 编写运行测试程序

  为了方便测试,这里只写一个小程序write.c,讲message序列化为string类型的字符串,然后再反序列化回来。测试程序如下:

  

#include "test.pb.h"
#include < stdio.h>
#include < string>

 int main()
 {
     TestMsg tmsg;
     tmsg.set_id(1001);
     tmsg.set_describe("this is a describe.");

     std::string s;
     tmsg.SerializeToString(&s);
     printf("%s\n",s.c_str());

     TestMsg msg2;
     msg2.ParseFromString(s);
     printf("id:%d\t describe:%s\n",msg2.id(), msg2.describe().c_str());

     return 0;
 }

  编译和运行程序。

c++ -o write write.cc test.pb.cc pkg-config --cflags --libs protobuf

  运行结果:

  this is a describe.

  id:1001 describe:this is a describe.

版权声明:本文为博主原创文章,未经博主允许不得转载。

时间: 2024-11-05 19:44:13

protobuf 简单入门的相关文章

protobuf c++入门

1.在.proto文件中定义消息格式 2.使用protobuf编译器 3.使用c++ api来读写消息 0.为何使用protobuf? 1.原始内存数据结构,可以以二进制方式sent/saved.这种方式需要相同的内存布局和字节序. 2.以ad-hoc方式将数据项编码成一个简单字符串----比如,将4个int类型编码成"12:3:-23:67".这种方式简灵活.适用于简单数据. 3.将数据序列化为XML.这种方式很流行,因为xml可读性好,编码解码方便,性能也好.仅仅XML dom树比

正则表达式简单入门

 正则表达式简单入门    正则表达式在平常编程中有着大量的应用,对于任何一个想学习编程的人来说,正则表达式是一个必须掌握的知识. 废话不多说,下面先对正则表达式做一个简单的入门介绍,在后续的文章中,将会进行详细的介绍.    一.元字符 元字符一共有12个:$ ( ) [ { ? + * . ^ \ | 元字符有特殊的含义,如果要使用其字面值,则必须对其进行转义. 如: \$  \*  \( 等等 二.控制字符或不可打印字符 \a  警报 \e  退出 \f  换页 \n  换行 \r 

程序员,一起玩转GitHub版本控制,超简单入门教程 干货2

本GitHub教程旨在能够帮助大家快速入门学习使用GitHub,进行版本控制.帮助大家摆脱命令行工具,简单快速的使用GitHub. 做全栈攻城狮-写代码也要读书,爱全栈,更爱生活. 更多原创教程请关注头条号.每日更新.也可以添加小编微信:fullstackCourse.一起交流,获取最新全栈教程信息.因为FQ原因,不能下载客户端的同仁,可以关注后回复“GitHub客户端”获取安装软件. 上篇教程:GitHub这么火,程序员你不学学吗? 超简单入门教程 干货 GitHub概念部分出现了一丝纰漏.为

iBatis简单入门教程

iBatis 简介: iBatis 是apache 的一个开源项目,一个O/R Mapping 解决方案,iBatis 最大的特点就是小巧,上手很快.如果不需要太多复杂的功能,iBatis 是能够满足你的要求又足够灵活的最简单的解决方案,现在的iBatis 已经改名为Mybatis 了. 官网为:http://www.mybatis.org/ 搭建iBatis 开发环境: 1 .导入相关的jar 包,ibatis-2.3.0.677.jar .mysql-connector-java-5.1.6

Asp.Net MVC学习总结(一)——Asp.Net MVC简单入门

出处:http://www.cnblogs.com/SeeYouBug/p/6401737.html 一.MVC简单入门 1.1.MVC概念 视图(View) 代表用户交互界面,对于Web应用来说,可以概括为HTML界面,但有可能为XHTML.XML和Applet. 模型(Model) 表示用户对其数据的操作的一个封转.可以分为视图模型(view model)和领域模型(domain models),视图模型就是在视图与控制器之间传输数据的一个封转,而领域模型就是业务逻辑,后台数据模型等的一个集

Java日志系统---Logger之简单入门

Java 中自带的日志系统,今天抽空了解了一点,算是入了门,所以将自己的一些心得记录下来,以备日后查看,有兴趣的朋友,看到此文章,觉得有错误或需要添加的地方,请在下方评论留言,大家可以共同进步,谢谢:) Java中关于日志系统的API,在 java.util.logging 包中,在这个包中,Logger类很重要. Logger类是用来记录 某个级别的日志消息: 级别共分为以下几类,从上倒下,级别依次下降: SEVERE(严重)------级别最高 WARNING(警告) INFO CONFIG

响应式网页设计简单入门(强烈推薦!!!!)

响应式网页设计简单入门 Overview: 构造基本的HTML页面 动态加载样式表 Viewport 字体缩放 侧边栏 导航菜单 图片自适应 其他 总结 说到响应式网页设计(Responsive web design),最近在谷歌加上碰到个奇葩贴子,通过一个原始到无法再简单的网页Motherfucking Website及满屏幕的fuck道出了网页设计的真谛,这孩子不是个激进分子就是个报复社会型的货没错,虽然整篇文章就像是泼妇骂街,但我特么是笑着读完的.. 统计了下全文共用Fuck (包括fuc

Android HttpGet() 请求简单入门实例

HttpClient httpclient = new DefaultHttpClient(); String url = "http://example.com"; List<NameValuePair> params = new ArrayList<NameValuePair>(); params.add( new BasicNameValuePair( "param", "value" ) ); URI uri =

delphi指针简单入门

delphi指针简单入门:         看一个指针用法的例子:     1         var     2             X,   Y:   Integer;       //   X   and   Y   整数类型     3             P:   ^Integer;           //   P   指向整数类型的指针     4         begin     5             X   :=17; //   给   X   赋值     6