protobuf博客截取

博客1地址

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 = 1;
    required string password = 2;
}

解析:看到消息定义中的 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 等于该字段的长度,所以上面的输出实际上是:

10 6 97 97 97 97 97 97 97 6 49 49 49 49 49 49

但这是所有字段都是字符串的情况,如果有 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中解析出消息



牛博客地址:IBM博客


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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值