用Maven实现一个protobuf的Java例子
2023-09-27 14:25:21 时间
注:试验环境在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添加
<dependencies> <dependency> <groupId>com.google.protobuf</groupId> <artifactId>protobuf-java</artifactId> <version>3.4.0</version> </dependency> </dependencies>
<build> <extensions> <extension> <groupId>kr.motd.maven</groupId> <artifactId>os-maven-plugin</artifactId> <version>1.4.1.Final</version> </extension> </extensions> <plugins> <plugin> <groupId>org.xolstice.maven.plugins</groupId> <artifactId>protobuf-maven-plugin</artifactId> <version>0.5.0</version> <configuration> <protocArtifact> com.google.protobuf:protoc:3.1.0:exe:${os.detected.classifier} </protocArtifact> <pluginId>grpc-java</pluginId> </configuration> <executions> <execution> <goals> <goal>compile</goal> <goal>compile-custom</goal> </goals> </execution> </executions> </plugin> </plugins>
</build>
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. 测试
把生成的类考的代码路径下,用下面测试用例测试
package com.jihite; import com.google.protobuf.InvalidProtocolBufferException; import org.junit.Test; public class protobufTest { @Test public void testN() throws InvalidProtocolBufferException { 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 (byte b : 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: 1 name: "jihite" email: "jihite@jihite.com" ===Person Byte: 811861061051041051161012617106105104105116101641061051041051161014699111109================ after id:1 after name:jihite after email:jihite@jihite.com
相关文章
- Java ArrayList、string、string[]之间的转换
- 并发编程(十三)—— Java 线程池 实现原理与源码深度解析 之 Executors(三)
- Java 基础【11】.class getClass () forName() 详解
- 从零构建Java项目(Maven+SpringBoot+Git) #02 奥斯丁项目
- 使用Eclipse-Maven-git做Java开发(3)--Eclipse的安装和配
- Java入门到精通——工具篇之Maven概述
- java 使用正则表达式从网页上提取网站标题
- java实现微信支付宝等多个支付平台合一的二维码支付(maven+spring springmvc mybatis框架)
- 将Java项目从maven迁移到gradle
- IntelliJ IDEA 创建 hello world Java web Maven项目从头到尾都有图有真相2017版本
- 图文详解 IntelliJ IDEA 15 创建 Maven 构建的 Java Web 项目(使用 Jetty 容器)
- JAVA eclipse Maven项目红叹号解决方案
- JAVA实现输出九九乘法表
- JAVA 日期工具类:日期获取周,获取指定周周一周日,某月月初月末日期,日期时间戳字符串转换,日期加减等
- 【java web篇】项目管理构建工具Maven简介以及安装配置
- java:Maven简介
- 持续集成案例学习:Docker、Java与Maven
- 已解决maven中出现java.lang.ClassNotFoundException: org.apache.http.entity.mime.content.ContentBody异常的正确解决方
- Java中将JDK中tools.jar配置在maven中
- 大数据必学Java基础(一百一十六):Application域监听器
- maven单元测试报java.lang.IllegalStateException: Failed to load ApplicationContext