前言
google 的 protoBuf 为数据化存储格式,RPC 数据交换格式,支持跨语言。使用 protobuf 编译器能自动生成代码,Protobuf 是将类的定义使用.proto 文件进行描述,然后通过 protoc.exe 编译器根据.proto 自动生成.java 文件.
将.proto文件转化为.java 文件
定义一个Student.proto 文件 代码如下
syntax = "proto3"; //版本
option optimize_for = SPEED; //加快解析
option java_outer_classname = "MyDataInfo"; //生成的外部类名,同时也是文件名
message Student { //会在StudentPojo 外部类生成一个内部类Student,他是真正发送的pojo对象
int32 id = 1; //Student类中有一个属性名字为ID,类型为int32(protobuf类型),1表示序号,不是值
string name = 2;
}
enum DateType {
StudentType = 0; //在proto3中,要求enum的编号从0开始
WorkerType = 1;
}
下载protoc.exe
下载地址为protoc.exe下载地址
将.proto文件放在exe文件的同一目录中。
使用命令protoc.exe --java_out=. Student.proto
生成.java文件。结果如下
这里我使用的protoc的版本是3.16.0,项目引入的依赖为
<dependency>
<groupId>com.google.protobuf</groupId>
<artifactId>protobuf-java</artifactId>
<version>3.11.4</version>
</dependency>
获得student 对象使用
MyDataInfo.Student.newBuilder().setId(1).setName("张三").build();
进行获取