b 序列化工具protobuffer 介绍

文章目录java版基础使用1、protobuf的安装2、定义`.proto`文件3、编译4、.proto与java格式映射5、额外的方法6、解析和序列化write a Protocol BufferReading A Message7、实际使用的参考ProtoBuf的编码1、一个简单的message2、Base 128 Varints3、数据类型 Message Structure4、更多数据类型(double、float、string)5、optional和repeated 属性的编码6、注意事项prot
摘要由CSDN通过智能技术生成

—> go to 总目录


protocal buffer google出品,平台无关&语言无关– .proto文件可以和java和c++转化
思路是先是无脑的使用一下,然后介绍不同字段是怎么编码的,然后再介绍protobuf的语法。

java版基础使用

以下会通过一个简单的示例来介绍protobuf的基本使用

  • 安装protobuff编译器
  • 定义.proto文件
  • protoc -I=$SRC_DIR --java_out=$DST_DIR $SRC_DIR/addressbook.proto指令编译
  • 用javaAPI去读取

1、protobuf的安装

官网:需要安装protobuf编译器,根据自己需要下载对应的编译包。编译器列表

2、定义.proto文件

syntax = "proto2";

package tutorial;

option java_package = "com.example.tutorial";
option java_outer_classname = "AddressBookProtos";

message Person {
  required string name = 1;
  required int32 id = 2;
  optional string email = 3;

  enum PhoneType {
    MOBILE = 0;
    HOME = 1;
    WORK = 2;
  }

  message PhoneNumber {
    required string number = 1;
    optional PhoneType type = 2 [default = HOME];
  }

  repeated PhoneNumber phones = 4;
}

message AddressBook {
  repeated Person people = 1;
}
字段 描述
syntax protobuf版本,目前已更新到proto3
package 指定包名:默认包名
option java_package 指定包名,实际包名。如果该字段有定义,那么就使用 java_package,没有的话就使用package作为包名,为了避免碰撞即使有该字段,也要定义package
option java_outer_classname 指定类名,编译后就会生成com.example.tutorial.AddressBookProtos类,如果没有定义该字段,默认使用文件名作为class名称,比如my_proto.proto会使用MyProto作为文件名
required string name required表示字段为必要字段。
optinal 可选,没有该属性时,会被赋成默认值:string为"",int 为0;
repeated 数组,编译后的对象为phones=[187***,182**,…]
enum 枚举类型
=1、=2 标记在每一个属性上,作为唯一的tag,被用于二进制编码。范围是1~(2^29)-1,使用1-15时会使用少于一个byte标识,最常用的(后面编译会解释为什么)

3、编译

protoc -I=$SRC_DIR --java_out=$DST_DIR $SRC_DIR/addressbook.proto

protoc --java_out=./ ./addressbook.proto

就会生成java的类文件com.example.tutorial.Address BookProtos.java

4、.proto与java格式映射

.proto不同的字段定义会生成对应的api

// required string name = 1;
public boolean hasName();
public String getName();

// required int32 id = 2;
public boolean hasId();
public int getId();

// optional string email = 3;
public boolean hasEmail();
public String getEmail();

// repeated .tutorial.Person.PhoneNumber phones = 4; repeated生成list
public List<PhoneNumber> getPhonesList();
public int getPhonesCount();
public PhoneNumber getPhones(int index);

同时构造器Person.Builder会生成以下的方法

// required string name = 1;
public boolean hasName();
public java.lang.String getName();
public Builder setName(String value);
public Builder clearName();

// required int32 id = 2;
public boolean hasId();
public int getId();
public Builder setId(int value);
public Builder clearId();

// optional string email = 3;
public boolean hasEmail();
public String getEmail();
public Builder setEmail(String value);
public Builder clearEmail();

// repeated .tutorial.Person.PhoneNumber phones = 4;
public List<PhoneNumber
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值