博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Protobuf协议的Java应用例子
阅读量:4285 次
发布时间:2019-05-27

本文共 2895 字,大约阅读时间需要 9 分钟。

protobuf版本protoc-2.5.0-win32亲测成功

,全称:Protocol Buffer 
它跟JSON,XML一样,是一个规定好的数据传播格式。不过,它的序列化和反序列化的效率太变态了……

来看看几张图你就知道它有多变态。 
这里写图片描述

这里写图片描述

这里写图片描述


Protobuf的Java实例

一、 安装Protobuf

,解压。

如果你是Windows环境,则还要下载多一个东西。。

解压protobuf-2.5.0-windows.zip,把protoc.exe放在Protobuf安装目录下的src里。(其实放哪都可以)

二、 配置环境变量

编辑系统变量Path,添加Protoc.exe的存放目录。 
这里写图片描述

三、 Eclipse新建项目

我使用maven构建protobuf项目,方便引入protobuf--2.5.0.jar依赖。 
在项目根目录创建proto文件夹,存放proto文件。 
这里写图片描述 
maven依赖pom.xml

com.google.protobuf
protobuf-java
2.5.0
1
2
3
4
5
1
2
3
4
5

四、编写.proto文件

在proto文件夹下编写person-entity.proto,如下()

option java_outer_classname = "PersonEntity";//生成的数据访问类的类名  message Person {    required int32 id = 1;//同上    required string name = 2;//必须字段,在后面的使用中必须为该段设置值    optional string email = 3;//可选字段,在后面的使用中可以自由决定是否为该字段设置值}   
1
2
3
4
5
6
1
2
3
4
5
6

四、使用protoc.exe编译成java类

有两种方法: 
1. 使用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程序 }}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16

命令格式如下。

protoc.exe -I=proto的输入目录 --java_out=java类输出目录 proto的输入目录包括包括proto文件 
1
1

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());    }} 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24

输出如下 
这里写图片描述


后记

我想,拿protobuf协议储存数据,或者作为聊天文本的传输协议,那效率肯定让人咋舌。嘿嘿。

你可能感兴趣的文章
数据挖掘开源软件:WEKA基础操作
查看>>
Python一些容易忽略的知识
查看>>
Ubuntu(-13.10)中安装JDK图文详解教程
查看>>
Hadoop2.2.0单节点安装和配置环境图文详解
查看>>
数据挖掘学习笔记--决策树C4.5
查看>>
数据挖掘学习笔记之人工神经网络(一)
查看>>
数据挖掘学习笔记之人工神经网络(二)
查看>>
人工神经网络关键核心知识点
查看>>
贝叶斯学习--极大后验概率假设和极大似然假设
查看>>
贝叶斯学习--极大后验假设学习
查看>>
朴素贝叶斯分类器
查看>>
贝叶斯学习举例--学习分类文本
查看>>
hadoop HDFS原理基础知识
查看>>
数据挖掘十大算法----EM算法(最大期望算法)
查看>>
android StrictMode应用
查看>>
TabHost的两种使用方法
查看>>
Android---TextView属性详解
查看>>
K近邻算法基础:KD树的操作
查看>>
数据挖掘十大算法--K近邻算法
查看>>
android对话框(Dialog)的用法
查看>>