protobuf?的Java開發包:jprotobuf
jprotobuf是針對Java程序開發一套簡易類庫,目的是簡化java語言對protobuf類庫的使用
使用jprotobuf可以無需再去了解.proto文件操作與語法,直接使用java注解定義字段類型即可。
環境要求
JDK 6 或以上版本
API使用說明
示例:假如需要定義protobuf定義一個數據接口,包含兩個屬性,一個是string,一個是int32
傳統protobuf使用過程
a 定義.proto說明文件. test.proto
package pkg;
option java_package = "com.baidu.bjf.remoting.protobuf";
//這里聲明輸出的java的類名
option java_outer_classname = "SimpleTypeTest";
message InterClassName {
required string name = 1;
required int32 value = 2;
}
b 使用protoc.exe 編譯.proto文件
protoc --java_out=src test.proto
c 編譯生成的Java文件,利用protobuf API進行序列化與反序化操作
序列化操作:
InterClassName icn = InterClassName.newBuilder().setName("abc") .setValue(100).build(); byte[] bb = icn.toByteArray();
反序化操作
byte[] bb = ...; InterClassName icn = InterClassName.parseFrom(bb);
使用jprotobuf API 簡化開發
a 使用注解直接使用pojo對象
import com.baidu.bjf.remoting.protobuf.FieldType; import com.baidu.bjf.remoting.protobuf.annotation.Protobuf; /** * A simple jprotobuf pojo class just for demo. * * @author xiemalin * @since 1.0.0 */ public class SimpleTypeTest { @Protobuf(fieldType = FieldType.STRING, order = 1, required = true) private String name; @Protobuf(fieldType = FieldType.INT32, order = 2, required = false) private int value; public int getValue() { return value; } public void setValue(int value) { this.value = value; } }
b 使用jprotobuf API進行序列化與反序列化操作
Codec<SimpleTypeTest> simpleTypeCodec = ProtobufProxy .create(SimpleTypeTest.class); SimpleTypeTest stt = new SimpleTypeTest(); stt.name = "abc"; stt.setValue(100); try { // 序列化 byte[] bb = simpleTypeCodec.encode(stt); // 反序列化 SimpleTypeTest newStt = simpleTypeCodec.decode(bb); } catch (IOException e) { e.printStackTrace(); }
本文由用戶 jopen 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!