Protobuf协议的Java应用例子
2016-08-03 15:20
459 查看
Protobuf协议,全称:Protocol Buffer
它跟JSON,XML一样,是一个规定好的数据传播格式。不过,它的序列化和反序列化的效率太变态了……
来看看几张图你就知道它有多变态。
![](http://img.blog.csdn.net/20160803143859081)
![](http://img.blog.csdn.net/20160803143926655)
![](http://img.blog.csdn.net/20160803143945754)
如果你是Windows环境,则还要下载多一个东西。protobuf-2.5.0-windows.zip。
解压protobuf-2.5.0-windows.zip,把protoc.exe放在Protobuf安装目录下的src里。(其实放哪都可以)
![](http://img.blog.csdn.net/20160803145119862)
在项目根目录创建proto文件夹,存放proto文件。
![](http://img.blog.csdn.net/20160803150200947)
maven依赖pom.xml
1. 使用Java Rumtime执行cmd命令
2. 直接打开cmd运行命令也行。
![](http://img.blog.csdn.net/20160803151005609)
命令格式如下。
![](http://img.blog.csdn.net/20160803145741085)
生成的PersonEntity.java类
![](http://img.blog.csdn.net/20160803145845617)
输出如下
![](http://img.blog.csdn.net/20160803151628811)
它跟JSON,XML一样,是一个规定好的数据传播格式。不过,它的序列化和反序列化的效率太变态了……
来看看几张图你就知道它有多变态。
Protobuf的Java实例
一、 安装Protobuf
去Protobuf的GitHub下载,解压。如果你是Windows环境,则还要下载多一个东西。protobuf-2.5.0-windows.zip。
解压protobuf-2.5.0-windows.zip,把protoc.exe放在Protobuf安装目录下的src里。(其实放哪都可以)
二、 配置环境变量
编辑系统变量Path,添加Protoc.exe的存放目录。三、 Eclipse新建项目
我使用maven构建protobuf项目,方便引入protobuf-java-2.5.0.jar依赖。在项目根目录创建proto文件夹,存放proto文件。
maven依赖pom.xml
<dependency> <groupId>com.google.protobuf</groupId> <artifactId>protobuf-java</artifactId> <version>2.5.0</version> </dependency>
四、编写.proto文件
在proto文件夹下编写person-entity.proto,如下(proto协议的规则点这查看)option java_outer_classname = "PersonEntity";//生成的数据访问类的类名 message Person { required int32 id = 1;//同上 required string name = 2;//必须字段,在后面的使用中必须为该段设置值 optional string email = 3;//可选字段,在后面的使用中可以自由决定是否为该字段设置值 }
四、使用protoc.exe编译成java类
有两种方法:1. 使用Java Rumtime执行cmd命令
2. 直接打开cmd运行命令也行。
1. 使用Java Rumtime执行cmd命令
util包下新建GenerareClass类/** * protoc.exe * @author ganhaibin * */ public class GenerateClass { public static void main(String[] args) { String protoFile = "person-entity.proto";// String strCmd = "d:/dev/protobuf-master/src/protoc.exe -I=./proto --java_out=./src/main/java ./proto/"+ protoFile; try { Runtime.getRuntime().exec(strCmd); } catch (IOException e) { e.printStackTrace(); }//通过执行cmd命令调用protoc.exe程序 } }
命令格式如下。
protoc.exe -I=proto的输入目录 --java_out=java类输出目录 proto的输入目录包括包括proto文件
2. 直接打开cmd运行命令
生成的PersonEntity.java类
五、测试
编写Test类,模拟序列化和反序列化过程。public class Test { public static void main(String[] args) throws IOException { //模拟将对象转成byte[],方便传输 PersonEntity.Person.Builder builder = PersonEntity.Person.newBuilder(); builder.setId(1); builder.setName("ant"); builder.setEmail("ghb@soecode.com"); PersonEntity.Person person = builder.build(); System.out.println("before :"+ person.toString()); System.out.println("===========Person Byte=========="); for(byte b : person.toByteArray()){ System.out.print(b); } System.out.println(); System.out.println(person.toByteString()); System.out.println("================================"); //模拟接收Byte[],反序列化成Person类 byte[] byteArray =person.toByteArray(); Person p2 = Person.parseFrom(byteArray); System.out.println("after :" +p2.toString()); } }
输出如下
后记
我想,拿protobuf协议储存数据,或者作为聊天文本的传输协议,那效率肯定让人咋舌。嘿嘿。相关文章推荐
- Protobuf协议的Java应用例子
- Protobuf协议的Java应用例子
- Protobuf协议的Java应用例子
- Protobuf动态解析在Java中的应用 包含例子程序
- protobuf的简单应用,json和protocol Buffer的转换简单例子
- Google PB协议学习记录--一个简单的例子--如何编译.proto文件为.java文件
- java序列化/反序列化之xstream、protobuf、protostuff 的比较与使用例子
- java序列化/反序列化之xstream、protobuf、protostuff 的比较与使用例子
- protobuf (java应用实例)
- Java与Javascript交互(使用Protobuf协议)
- 【Protobuf】Protocol buffer在Java语言中的应用01
- java序列化/反序列化之xml、protobuf、protostuff 的比较与使用例子
- java序列化/反序列化之xstream、protobuf、protostuff 的比较与使用例子
- protobuf协议原理与应用
- Protobuf协议Java示例
- 用Maven实现一个protobuf的Java例子
- java序列化/反序列化之xstream、protobuf、protostuff 的比较与使用例子
- java序列化/反序列化之xml、protobuf、protostuff 的比较与使用例子
- protobuf 协议 windows 下 java 环境搭建
- Java中的Protobuf使用例子(转)