java protobuf 例子_用Maven实现一个protobuf的Java例子
注:試驗環境在Mac Idea環境下
1. 介紹Protocol Buffers
Protocal Buffers(簡稱protobuf)是谷歌的一項技術,用于結構化的數據序列化、反序列化,常用于RPC 系統(Remote Procedure Call Protocol System)和持續數據存儲系統。
其類似于XML生成和解析,但protobuf的效率高于XML,不過protobuf生成的是字節碼,可讀性比XML差,類似的還有json、Java的Serializable等。
很適合做數據存儲或 RPC 數據交換格式。可用于通訊協議、數據存儲等領域的語言無關、平臺無關、可擴展的序列化結構數據格式。
2. Idea 安裝protobuf插件
安裝插件protobuf Support,之后重啟
3. 配置依賴
pom.xml添加
com.google.protobuf
protobuf-java
3.4.0
kr.motd.maven
os-maven-plugin
1.4.1.Final
org.xolstice.maven.plugins
protobuf-maven-plugin
0.5.0
com.google.protobuf:protoc:3.1.0:exe:${os.detected.classifier}
grpc-java
compile
compile-custom
4. 書寫proto文件
syntax = "proto3";
option java_package= "com.jihite";
option java_outer_classname= "PersonModel";
message Person {
int32 id= 1;
string name= 2;
string email= 3;
}
5. 轉化成Java文件
6. 測試
把生成的類考的代碼路徑下,用下面測試用例測試
packagecom.jihite;importcom.google.protobuf.InvalidProtocolBufferException;importorg.junit.Test;public classprotobufTest {
@Testpublic void testN() throwsInvalidProtocolBufferException {
PersonModel.Person.Builder builder=PersonModel.Person.newBuilder();
builder.setId(1);
builder.setName("jihite");
builder.setEmail("jihite@jihite.com");
PersonModel.Person person=builder.build();
System.out.println("before:" +person);
System.out.println("===Person Byte:");for (byteb : person.toByteArray()) {
System.out.print(b);
}
System.out.println("================");byte[] byteArray =person.toByteArray();
PersonModel.Person p2=PersonModel.Person.parseFrom(byteArray);
System.out.println("after id:" +p2.getId());
System.out.println("after name:" +p2.getName());
System.out.println("after email:" +p2.getEmail());
}
}
結果
before:id: 1name:"jihite"email:"jihite@jihite.com"
===Person Byte:811861061051041051161012617106105104105116101641061051041051161014699111109================after id:1after name:jihite
after email:jihite@jihite.com
總結
以上是生活随笔為你收集整理的java protobuf 例子_用Maven实现一个protobuf的Java例子的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Sensor Tower:1 月共 41
- 下一篇: 如何在Chrome上可以登录Google