protobuf使用(二)android ndk

简介

 

1.   官方文档中提到一些protobuf的优点, protobuf灵活高效的结构化数据存储格式.方便用于序列化, 适合做RPC的数据交换.

2.   相比 XML , protobuf 比 XML 更小、更快、更简单.仅需要写一个 *.proto 文件描述需要的数据结构, protobuf会帮助你实现相关类和方法(自动化多好!).

3.   目前提供 C++, Java, Python, Go, C#等多种语言 的API
 

Protobuf 的优点

Protobuf 有如 XML,不过它更小、更快、也更简单。你可以定义自己的数据结构,然后使用代码生成器生成的代码来读写这个数据结构。你甚至可以在无需重新部署程序的情况下更新数据结构。只需使用 Protobuf 对数据结构进行一次描述,即可利用各种不同语言或从各种不同数据流中对你的结构化数据轻松读写。

它有一个非常棒的特性,即“向后”兼容性好,人们不必破坏已部署的、依靠“老”数据格式的程序就可以对数据结构进行升级。这样您的程序就可以不必担心因为消息结构的改变而造成的大规模的代码重构或者迁移的问题。因为添加新的消息中的 field 并不会引起已经发布的程序的任何改变。

Protobuf 语义更清晰,无需类似 XML 解析器的东西(因为 Protobuf 编译器会将 .proto 文件编译生成对应的数据访问类以对 Protobuf 数据进行序列化、反序列化操作)。

使用 Protobuf 无需学习复杂的文档对象模型,Protobuf 的编程模式比较友好,简单易学,同时它拥有良好的文档和示例,对于喜欢简单事物的人们而言,Protobuf 比其他的技术更加有吸引力。

Protobuf 的不足

Protbuf 与 XML 相比也有不足之处。它功能简单,无法用来表示复杂的概念。

XML 已经成为多种行业标准的编写工具,Protobuf 只是 Google 公司内部使用的工具,在通用性上还差很多。

由于文本并不适合用来描述数据结构,所以 Protobuf 也不适合用来对基于文本的标记文档(如 HTML)建模。另外,由于 XML 具有某种程度上的自解释性,它可以被人直接读取编辑,在这一点上 Protobuf 不行,它以二进制的方式存储,除非你有 .proto 定义,否则你没法直接读出 Protobuf 的任何内容

Protobuf 简单使用

简单的person.proto文件:

syntax = "proto3";
package tutorial;
 
message Person {
   int32 id = 1;
   string name = 2;
   string email = 3;
}

使用这个和文件和下载的工具可以写成代码,生成C++ 批处理工具 person.bat

protoc --cpp_out=./ person.proto

上面的 cpp 换成 java 就可以成生 java 代码。这个生成的类似 java bean 类。支持序列化

下 面看一下简单使用

#include "person.pb.h"

    // 赋值
    tutorial::Person person ;
    person.set_name("testname");
    person.set_id(120);
    person.set_email("liguoqing@hjimi.com");
	//序列化 变字节,就可以传递了
    int blen = person.ByteSize();
    uint8_t *buf = new uint8_t[blen+1];
    memset(buf,0,blen+1);
    int serRet = person.SerializeToArray(buf, blen);
	
	//反序列化 ,就可以直接得到数据
	tutorial::Person nPerson ;
    int parseRet = nPerson.ParseFromArray(buf,blen);
    
    nPerson.name();

使用进阶

如果需要传递数组呢?

person.proto

syntax = "proto3";
package tutorial;
 
message Person {
   int32 id = 1;
   string name = 2;
   string email = 3;
}
message Data {
 repeated Person person = 1;
}

重新用它生成文件,就可以传递数组

    tutorial::Data data ;
    string  stringbuf1;
    for(int i =1;i<101;i++)
    {
         tutorial::Person *person1 = data.add_person();
         stringbuf1=("abd" );
         person1->set_name(stringbuf1);
         stringbuf1 ="lihaozhang@163.com" ;
         person1->set_email(stringbuf1);
         person1->set_id(i);
    }

    int total = data.ByteSize();
    uint8_t *Databuf = new uint8_t[total+1];
    memset(Databuf,0,total+1);
    int dataRet = data.SerializeToArray(Databuf, total);

解析不再写了。粘一个更详细链接:https://blog.csdn.net/shensky711/article/details/69696392

想了解更细节可以看官方文档:

 

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

恋恋西风

up up up

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值