A useful utility library for java programmer using google protobuf
A useful utility library for java programmer to use google protobuf library.
jprotobuf是针对Java程序开发一套简易类库,目的是简化java语言对protobuf类库的使用
使用jprotobuf可以无需再去了解proto文件操作与语法,直接使用java注解定义字段类型即可。
jprotobuf工作原理如下:
jprotobuf 主要性能消耗在 扫描类上注解,动态生成代码编译的过程。
在执行序列化与反序列化的过程中,几乎与protobuf生成的代码效率等同。
如果使用预编译插件,则无需在运行中进行代码生成与编译,效率更高
JProtobuf-rpc-socket 基于socket的高性能RPC实现
访问地址:https://github.com/jhunters/Jprotobuf-rpc-socket
JProtobuf-rpc-http 基于JProtobuf的RPC实现,支持直接从IDL定义脚本发布RPC服务
访问地址:https://github.com/jhunters/JProtobuf-rpc-http
golang 协议实现: https://github.com/baidu-golang/baidurpc
@ProtobufClass
public class SimpleTypeTest {
private String name;
private int value;
public int getValue() {
return value;
}
public String getName() {
return name;
}
}
// example code for usage
Codec<SimpleTypeTest> simpleTypeCodec = ProtobufProxy
.create(SimpleTypeTest.class);
SimpleTypeTest stt = new SimpleTypeTest();
stt.name = "abc";
stt.value = 100
try {
// 序列化
byte[] bb = simpleTypeCodec.encode(stt);
// 反序列化
SimpleTypeTest newStt = simpleTypeCodec.decode(bb);
} catch (IOException e) {
e.printStackTrace();
}
jprotobuf-1.x JDK 6 或以上版本
<dependency>
<groupId>com.baidu</groupId>
<artifactId>jprotobuf</artifactId>
<version>1.13.3</version>
</dependency>
jprotobuf-2.x JDK 7 或以上版本
<dependency>
<groupId>com.baidu</groupId>
<artifactId>jprotobuf</artifactId>
<version>2.4.20</version>
</dependency>
jprotobuf-android
<dependency>
<groupId>com.baidu</groupId>
<artifactId>jprotobuf-android</artifactId>
<version>1.1.3</version>
</dependency>
插件使用方法,请阅读文档Full docs
jprotobuf-precompile-plugin 支持maven编译时同时进行jprotobuf对象的预编译操作.
注:plugin版本建议使用>=1.2.0, jprotobuf 支持版本>=1.9.4
1.2.15和2.0.11版本之后,支持在预编译阶段生成 proto声明文件的功能, 文件生成位置在当前类的相同目录下。具体使用方式详见下面插件使用说明
<dependency>
<groupId>com.baidu</groupId>
<artifactId>jprotobuf-precompile-plugin</artifactId>
<version>1.4.5</version>
</dependency>
插件版本1.x | 支持的jprotobuf版本 | 说明 |
---|---|---|
<=1.2.10 | <=1.11.4 | |
>=1.2.11 | >=1.11.5 |
// 2.x支持版本
<dependency>
<groupId>com.baidu</groupId>
<artifactId>jprotobuf-precompile-plugin</artifactId>
<version>2.2.9</version>
</dependency>
插件版本2.x | 支持的jprotobuf版本 | 说明 |
---|---|---|
<=2.2.5 | <=2.0.4 | |
>=2.2.6 | >=2.0.5 |
plugins {
id 'com.baidu.jprotobuf' version '1.1.1'
}
QQ: 644867264 (入群口号: jprotobuf)
JProtobuf is Apache 2.0 licensed.