Protocol Buffers - PB协议概述

目录

一. 什么是PB

二. 定义(编写实体描述文件)

三. 编译(从描述文件到java类)

四. 项目中使用

五. 扩展

一. 什么是PB

� ProtocolBuffers-Google'sdatainterchangeformat

� 一种语言无关、平台无关、扩展性好的用于通信协议、 数据存储的结构化数据串行化方法。

� Java、C++或Python开发者

� 谷歌的数据交换格式

� 类似 JSON, XML

� GITHUB:https://github.com/google/protobuf/

为什么不用XML

� ProtocolBuffer拥有多项比XML更高级的串行化结构数

据的特性,ProtocolBuffer:

� ·更简单

� ·小3-10倍

� ·快20-100倍

� ·更少的歧义

� ·可以方便的生成数据存取类

Protocol Buffers

� ProtocolBuffer是用于结构化数据串行化 的灵活、高效、自动的方法,有如XML, 不过它更小、更快、也更简单。你可以定 义自己的数据结构,然后使用代码生成器 生成的代码来读写这个数据结构。你甚至 可以在无需重新部署程序的情况下更新数 据结构。

二. 定义(编写实体描述文件) 建立一个msg.proto文件

option java_package = "com.protobuftest.protobuf";
option java_outer_classname = "PersonProbuf";
  message Person {
  required string name = 1;
  required int32 id = 2;
  optional string email = 3;
}
enum PhoneType {
    MOBILE = 0; HOME = 1; WORK = 2;
}

三. 编译(从描述文件到java类)

  1. 下载安装编译器。

  2. 找到.proto文件位置

  3. 运行编译器,指定源目录和目标目录,定位你的 .proto 文件到源目录,然后执行:

protoc -I=$SRC_DIR --python_out= $DST_DIR addressbook.protoPython    –python_out

四. 在项目(工程)中使用

  1. 加入类库jar包

  2. 加入刚刚生成的 实体类文件

项目中使用 实体类的转换

(1) 实体转字节

String imei = getImei(); ObdRightBean.ObdRightRequest obdRightRequest;

.

obdRightRequest = 
      ObdRightBean.ObdRightRequest.newBuilder().setImei(imei).build();

//转换成字节 obdRightRequest.toByteArray()

(2) 字节转实体

  ObdRightBean.ObdRightResponse obdProductResponse = null;

  obdProductResponse =   
        ObdRightBean.ObdRightResponse.parseFrom(bytes2);

  int code = obdProductResponse.getCode();

讨论

� HTTP+PB VS HTTPS+JSON ?

� PB协议中间序列号时会进行压缩,网络

传输更少 ?

� PB是加密的吗? 还需要对字节DESC吗? � 开发效率? JSON更快?学习曲线?

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值