1、下载地址:https://code.google.com/p/protobuf/downloads/list

安装 ./configure && make && make install

2、试执行 protoc 命令,如果提示链接库错误,则执行 ldconfig

3、编译 .proto 文件成 C++ 头文件和源文件

protoc Login.proto --cpp_out=. 

注:可以使用 protoc *.proto --cpp_out=. 批量编译多个 proto 文件。

4、上面的 Login.proto 文件内容如下:

package s3;
message Login
{
required string username = ;
required string password = ;
}

解析:看到消息定义中的 1,2 吗?每个字段都有唯一的一个标识符,这些标识符是用来在消息的二进制格式中识别各个字段的,一旦开始使用就不能够再改变。其中 1~15 的标识号在编码的时候会占用一个字节,16~2047 的标识号则占用2个字节。所以应该为那些频繁出现的消息元素保留 1~15  的标识号。

最小的标识号可以从1开始,最大到229 - 1, or 536,870,911。不可以使用其中的[19000-19999]的标识号, Protobuf协议实现中对这些进行了预留。如果非要在.proto文件中使用这些预留标识号,编译时就会报警。

5、编写测试文件 test.cpp 如下:

#include "Login.pb.h"
#include <iostream>
#include <fstream> bool write()
{
s3::Login obj;
obj.set_username("aaaaaa");
obj.set_password("111111");
std::fstream output("Login.log", std::ios::out | std::ios::trunc | std::ios::binary);
if(!obj.SerializeToOstream(&output))
{
return false;
}
return true;
} bool read()
{
s3::Login obj;
std::fstream input("Login.log",std::ios::in | std::ios::binary);
if(!obj.ParseFromIstream(&input))
{
return false;
}
std::cout<<"username:"<<obj.username()<<std::endl;
std::cout<<"password:"<<obj.password()<<std::endl;
return true;
} int main()
{
if(write())
read();
}

上面会输出: tianya123456

解析:表面上看是12个字符,实际上是12+3=15个字符,以ASCII 10 为开头字符,然后每个字段前有一个字符,其ASCII 等于该字段的长度,所以上面的输出实际上是:

               

但这是所有字段都是字符串的情况,如果有 int32 的话,就不一样了,反正注意看到的长度不是真正的长度就好了,pb能够进行序列化和反序列化就是依据这个来的。

另外,开发过程中需要经常查看数据,可以调用对象的 DebugString() 函数即可返回可读性良好的数据。

6、编写 CMakeLists.txt 如下:

add_executable(test test.cpp Login.pb.cc)
target_link_libraries(test protobuf)

或者直接使用:

g++ test.cpp Login.pb.cc -o test -lprotobuf

7、常用方法:

bool SerializeToString(string* output) const:        序列化消息,将存储字节的以string方式输出。注意字节是二进制,而非文本;

bool ParseFromString(const string& data):            解析给定的string

bool SerializeToOstream(ostream* output) const:      写消息给定的c++  ostream中

bool ParseFromIstream(istream* input):               从给定的c++ istream中解析出消息

8、参考:

http://hideto.iteye.com/blog/445848

开发者指南:http://blog.163.com/jiang_tao_2010/blog/static/12112689020114305013458/

二、JAVA版:

1、下载 apache-maven-3.1.0-bin.tar.gz 解压,并把 apache-maven-3.1.0/bin 目录添加到 PATH 变量

2、安装 JAVA 环境, yum install java && yum install java-devel

3、下载 protobuf-2.5.0.tar.gz 解压,先安装 protobuf ,见上面,略。然后 进入 protobuf-2.5.0/java 目录,依次执行 mvn test && mvn install && mvn package

4、经过第三步,在 target 目录下生成 .jar 文件

详细参考:

http://blog.csdn.net/sunxinhere/article/details/8225302

http://blog.csdn.net/dodo_check/article/details/8573592

Unity中的使用:

1、首先使用第三方的C#库 protobuf-net,首页为 https://code.google.com/p/protobuf-net/

下载方式有两种 ,一种是直接下载,一种是通过官方推荐的工具下载,我是直接下载的:

https://code.google.com/p/protobuf-net/downloads/list

下载下来之后,里面有一个工具 protogen.exe,可以用来把 .proto 文件生成 C# 的格式:

protogen.exe -i:Login.proto  -o:Login.cs

2、关于 protobuf-net 的dll 在unity发布到IOS机器上是无法使用的,解决方案请参考:

http://game.ceeger.com/forum/read.php?tid=13479

3、关于 unity 的版本控制:

http://blog.k-res.net/archives/1113.html

4、关于两个SVN需要共用的资源,如服务端和客户端使用同一份 proto 文件夹,可以使用SVN的外部命令,参考下面的网页:

http://blog.csdn.net/echoisland/article/details/6584875

比如把存放在服务端的 proto 文件夹同步到客户端的某个目录下,命令如下:

svn propset svn:externals "proto svn://172.16.116.200/coldjoke/Trunk/server/proto" .

表示把 svn://172.16.116.200/coldjoke/Trunk/server/proto 同步到当前目录(由命令最后面的 . 决定)的 proto 文件夹。

如果要删除这个外部命令,可以使用:

svn propdel svn:externals

需要注意的是,服务端的任何修改 proto 文件夹内的操作,都会及时可更新到客户端;但客户端如果修改了 proto 文件夹中的内容,即使在有权限的情况下,也必须进入 proto 文件夹中提交才可生效,在 proto 文件夹外部提交是不会提交 proto 的内容的,因为本质上, proto 文件夹是对应着另一个不同的SVN。所以这种方法,更适用于一方较频繁修改,而另一方一般只需要同步的情况下,否则有一方的操作将会有些许麻烦。如还可适用于美术的SVN,同步到客户端的相应SVN目录;策划的脚本SVN同步到服务端和客户端的目录等需求。

http://game.ceeger.com/forum/read.php?tid=13479

解决 protobuf 在 unity3d 中使用烧IOS版本不能联网的问题:

http://blog.csdn.net/panda_bear/article/details/9949751

unity2d:

http://unity3d.9tech.cn/news/2014/0213/39832.html

unity 视频:

http://www.unitymanual.com/topic/video/index.html

protobuf的更多相关文章

  1. python通过protobuf实现rpc

    由于项目组现在用的rpc是基于google protobuf rpc协议实现的,所以花了点时间了解下protobuf rpc.rpc对于做分布式系统的人来说肯定不陌生,对于rpc不了解的童鞋可以自行g ...

  2. Protobuf使用规范分享

    一.Protobuf 的优点 Protobuf 有如 XML,不过它更小.更快.也更简单.它以高效的二进制方式存储,比 XML 小 3 到 10 倍,快 20 到 100 倍.你可以定义自己的数据结构 ...

  3. java netty socket库和自定义C#socket库利用protobuf进行通信完整实例

    之前的文章讲述了socket通信的一些基本知识,已经本人自定义的C#版本的socket.和java netty 库的二次封装,但是没有真正的发表测试用例. 本文只是为了讲解利用protobuf 进行C ...

  4. 在Wcf中应用ProtoBuf替代默认的序列化器

    Google的ProtoBuf序列化器性能的牛逼已经有目共睹了,可以把它应用到Socket通讯,队列,Wcf中,身为dotnet程序员一边期待着不久后Grpc对dotnet core的支持更期待着Wc ...

  5. protobuf的编译安装

    github地址:https://github.com/google/protobuf支持多种语言,有多个语言的版本,本文采用的是在centos7下编译源码进行安装. github上有详细的安装说明: ...

  6. 编译protobuf的jar文件

    1.准备工作 需要到github上下载相应的文件,地址https://github.com/google/protobuf/releases protobuf有很多不同语言的版本,因为我们需要的是ja ...

  7. protobuf学习(2)-相关学习资料

    protobuf官方git地址 protobuf官方英文文档   (你懂的需要FQ) protobuf中文翻译文档 protobuf概述          (官方翻译 推荐阅读) protobuf入门 ...

  8. google protobuf安装与使用

    google protobuf是一个灵活的.高效的用于序列化数据的协议.相比较XML和JSON格式,protobuf更小.更快.更便捷.google protobuf是跨语言的,并且自带了一个编译器( ...

  9. c# (ENUM)枚举组合类型的谷歌序列化Protobuf

    c# (ENUM)枚举组合类型的谷歌序列化Protobuf,必须在序列化/反序列化时加上下面: RuntimeTypeModel.Default[typeof(Alarm)].EnumPassthru ...

  10. dubbox 增加google-gprc/protobuf支持

    好久没写东西了,今年实在太忙,基本都在搞业务开发,晚上来补一篇,作为今年的收官博客.google-rpc 正式发布以来,受到了不少人的关注,这么知名的rpc框架,不集成到dubbox中有点说不过去. ...

随机推荐

  1. sax 解析 xml

    SAX(Simple API for XML) https://docs.oracle.com/javase/tutorial/jaxp/sax/parsing.html persons.xml &l ...

  2. 【poj3468】 A Simple Problem with Integers

    http://poj.org/problem?id=3468 (题目链接) 题意 给出一个序列,要求维护区间修改与区间求和操作. Solution 多年以前学习的树状数组区间修改又忘记了→_→. 其实 ...

  3. Java unserialize serialized Object(AnnotationInvocationHandler、ysoserial) In readObject() LeadTo InvokerTransformer(Evil MethodName/Args)

    Java unserialize serialized Object(AnnotationInvocationHandler.ysoserial) In readObject() LeadTo Tra ...

  4. (译)你应该知道的jQuery小技巧

    帮助提高你jQuery应用的简单小技巧 回到顶部按钮 图片预加载 判断图片是否加载完 自动修补破损图像 Hover切换class类 禁用输入 停止正在加载的链接 toggle fade/slide 简 ...

  5. python中set使用

    In [2]: a = set() # 常用操作1 In [3]: a Out[3]: set() In [4]: type(a) Out[4]: set In [5]: b = set([1, 3] ...

  6. 多线程引发OutOfMemoryException

    现象: 内存是绝对没有问题的,3g内存,发生异常时,任务管理器里显示,可用内存还有1G多!不知道什么原因! int i=0; while ((i++) < 2000) { try { Threa ...

  7. 一个WPF控件 诡异的MouseEvent 。

    背景: private System.Windows.Controls.Border _borderTouch; private bool _mouseDown = false;  private S ...

  8. [USACO2009 NOV GOLD]奶牛的图片

    校内题,不给传送门了. 以前做完NOIp2013的火柴排队那道题后,当时很担心NOIp会出那种题,因为贪心的规则能不能看出来真的要看运气.但是这类题做多了后发现其实那道题的规则其实是很多题都已经用到了 ...

  9. 1 构建Mysql+heartbeat+DRBD+LVS集群应用系统系列之DRBD的搭建

    preface 近来公司利润上升,购买了10几台服务器,趁此机会,把mysql的主从同步的架构进一步扩展,为了适应日益增长的流量.针对mysql架构的扩展,先是咨询前辈,后和同事探讨,准备采用Mysq ...

  10. 【原】redux学习笔记

    上周学习了flux,这周研究了一下redux,其实很早之前都已经在研究他们了,只是之前一直没搞懂,最近这两周可能打通了任督二脉,都算入门了. 写博客的目的主要是做一下笔记,总结一下思路,以及和大家交流 ...