当前位置: 首页 > 工具软件 > jprotobuf > 使用案例 >

JProtobuf

夔光霁
2023-12-01

JProtobuf

What is jprotobuf

  • jprotobuf是针对Java程序开发一套简易类库,目的是简化java语言对protobuf类库的使用
  • 使用jprotobuf可以无需再去了解proto文件操作与语法,直接使用java注解定义字段类型即可。

How it works

jprotobuf工作原理如下:

  • 扫描类上的注解的信息,进行分析(与protobuf读取proto文件进行分析过程相似)
    根据注解分析的结果,动态生成java代码进行protobuf序列化与反序列化的功能实现
  • 使用JDK6及以上的 code compile API进行编译后加载到classloader

Performace

  • jprotobuf 主要性能消耗在扫描类上注解,动态生成代码编译的过程。在执行序列化与反序列化的过程中,几乎与protobuf生成的代码效率等同。如果使用预编译插件,则无需在运行中进行代码生成与编译,效率更高

Fetures

  • 无需编写proto文件及繁琐的手工编译过程,支持基于POJO对象的注解方式,方便快捷。
  • 支持protobuf所有类型,包括对象嵌套,数组,枚举类型
  • 提供根据proto文件,动态生成代理对象,可省去POJO对象的编写工作。
  • 完整支持proto文件所有功能,包括内联对象,匿名对象,枚举类型
  • 提供从POJO对象的注解方式自动生成proto文件的功能, 方便proto描述文件的管理与维护
  • 提供预编译Maven插件,进一步提升运行性能,
  • 新增预编译gradle插件2.x版本。 支持TimeStamp类型, 与原生protobuf保持一致。 支持Date类型,使用long类型传递 docs

关联项目:

  • 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

Quick Start

@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();
}

Download

jprotobuf-1.x JDK 6 或以上版本

com.baidu jprotobuf 1.13.0

jprotobuf-2.x JDK 7 或以上版本

com.baidu jprotobuf 2.4.0

Download plugin

maven插件
jprotobuf-precompile-plugin 支持maven编译时同时进行jprotobuf对象的预编译操作.
注:plugin版本建议使用>=1.2.0, jprotobuf 支持版本>=1.9.4
1.2.15和2.0.11版本之后,支持在预编译阶段生成 proto声明文件的功能, 文件生成位置在当前类的相同目录下。具体使用方式详见下面插件使用说明

com.baidu jprotobuf-precompile-plugin 1.4.0 备注: precompile-plugin的版本 1.2.11 只支持 jprotobuf 1.11.5 及以上的版本。 其它版本请有 1.2.10及以下precompile plugin

// 2.x支持版本

com.baidu jprotobuf-precompile-plugin 2.2.0 备注: precompile-plugin的版本 2.0.5 只支持 jprotobuf 2.2.6 及以上的版本。 其它版本请有2.0.4及以下precompile plugin
 类似资料:

相关阅读

相关文章

相关问答