protobuf?的Java開發包:jprotobuf

jopen 10年前發布 | 41K 次閱讀 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();
        }

項目主頁:http://www.baiduhome.net/lib/view/home/1399297973671

 本文由用戶 jopen 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
 轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
 本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!