前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Protocol Buffers - PB协议概述

Protocol Buffers - PB协议概述

作者头像
张云飞Vir
发布2020-03-16 16:07:50
3.2K0
发布2020-03-16 16:07:50
举报
文章被收录于专栏:写代码和思考

目录

一. 什么是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文件

代码语言:javascript
复制
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 文件到源目录,然后执行:
代码语言:javascript
复制
protoc -I=$SRC_DIR --python_out= $DST_DIR addressbook.protoPython    –python_out

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

  1. 加入类库jar包
  2. 加入刚刚生成的 实体类文件

项目中使用 实体类的转换

(1) 实体转字节

代码语言:javascript
复制
String imei = getImei(); ObdRightBean.ObdRightRequest obdRightRequest;

.

代码语言:javascript
复制
obdRightRequest = 
      ObdRightBean.ObdRightRequest.newBuilder().setImei(imei).build();

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

(2) 字节转实体

代码语言:javascript
复制
  ObdRightBean.ObdRightResponse obdProductResponse = null;

  obdProductResponse =   
        ObdRightBean.ObdRightResponse.parseFrom(bytes2);

  int code = obdProductResponse.getCode();

讨论

� HTTP+PB VS HTTPS+JSON ?

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

传输更少 ?

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

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 目录
  • 一. 什么是PB
    • 为什么不用XML
      • Protocol Buffers
      • 二. 定义(编写实体描述文件) 建立一个msg.proto文件
      • 三. 编译(从描述文件到java类)
      • 四. 在项目(工程)中使用
        • 项目中使用 实体类的转换
        • 讨论
        相关产品与服务
        数据保险箱
        数据保险箱(Cloud Data Coffer Service,CDCS)为您提供更高安全系数的企业核心数据存储服务。您可以通过自定义过期天数的方法删除数据,避免误删带来的损害,还可以将数据跨地域存储,防止一些不可抗因素导致的数据丢失。数据保险箱支持通过控制台、API 等多样化方式快速简单接入,实现海量数据的存储管理。您可以使用数据保险箱对文件数据进行上传、下载,最终实现数据的安全存储和提取。
        领券
        问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档