一. 什么是PB
二. 定义(编写实体描述文件)
三. 编译(从描述文件到java类)
四. 项目中使用
五. 扩展
� ProtocolBuffers-Google'sdatainterchangeformat
� 一种语言无关、平台无关、扩展性好的用于通信协议、 数据存储的结构化数据串行化方法。
� Java、C++或Python开发者
� 谷歌的数据交换格式
� 类似 JSON, XML
� GITHUB:https://github.com/google/protobuf/
� ProtocolBuffer拥有多项比XML更高级的串行化结构数
据的特性,ProtocolBuffer:
� ·更简单
� ·小3-10倍
� ·快20-100倍
� ·更少的歧义
� ·可以方便的生成数据存取类
� ProtocolBuffer是用于结构化数据串行化 的灵活、高效、自动的方法,有如XML, 不过它更小、更快、也更简单。你可以定 义自己的数据结构,然后使用代码生成器 生成的代码来读写这个数据结构。你甚至 可以在无需重新部署程序的情况下更新数 据结构。
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;
}
protoc -I=$SRC_DIR --python_out= $DST_DIR addressbook.protoPython –python_out
(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更快?学习曲线?