protocolbuffer 在java中的使用 (windows平台)

原创 2016年05月31日 17:37:35
1、下载 protoc-2.6.1-win32.zip 

https://github.com/google/protobuf/releases?after=v3.0.0-alpha-1

压缩包内有一个protoc.exe,用来把proto的消息文件生成java实体类

2、建立一个Maven工程,添加protobuf-java的依赖。依赖的版本要和上面的protoc的版本保持一致
依赖包地址如下:
http://mvnrepository.com/artifact/com.google.protobuf/protobuf-java/2.6.1

<dependency>
    <groupId>com.google.protobuf</groupId>
    <artifactId>protobuf-java</artifactId>
    <version>2.6.1</version>
</dependency>

如果不是Maven功能,就单独下载这个jar包,然后把jar文件加入到已有的工程中去使用。

3、建立一个测试的msg.proto文件,内容如下:

option java_package = "com.protobuftest.protobuf";
option java_outer_classname = "PersonProbuf"; 

message Person {
 required string name = 1;
 required int32 id = 2;
 optional string email = 3;

 enum PhoneType {
   MOBILE = 0;
   HOME = 1;
   WORK = 2;
 }

 message PhoneNumber {
   required string number = 1;
   optional PhoneType type = 2 [default = HOME];
 }

 repeated PhoneNumber phone = 4;
}

message AddressBook {
 repeated Person person = 1;
}

4、生成 java文件:打开命令窗口(cmd),进入proto.exe目录下,执行如下命令:
protoc --java_out=../src ./msg.proto注意路径根据实际情况修改


生成在src下会生成对应的java类:



5、建立测试:


// 创建builder对象
PersonProbuf.Person.Builder builder = PersonProbuf.Person.newBuilder();
builder.setEmail("ggggggg@email.com");
builder.setId(1);
builder.setName("TestName");
builder.addPhone(PersonProbuf.Person.PhoneNumber.newBuilder().setNumber("13664262866")
.setType(PersonProbuf.Person.PhoneType.MOBILE));
builder.addPhone(PersonProbuf.Person.PhoneNumber.newBuilder().setNumber("02869387891")
.setType(PersonProbuf.Person.PhoneType.HOME));
// 通过builder转化为Person对象
Person person = builder.build();
// 将person对象转化为字节流
byte[] buf = person.toByteArray();

try {
// 通过字节流转化 为Person对象
Person person2 = PersonProbuf.Person.parseFrom(buf);
System.out.println(person2.getName() + ", " + person2.getEmail());
List<PhoneNumber> lstPhones = person2.getPhoneList();
for (PhoneNumber phoneNumber : lstPhones) {
System.out.println(phoneNumber.getNumber());
}
} catch (InvalidProtocolBufferException e) {
e.printStackTrace();
}

System.out.println(buf);


执行结果:



相关文章推荐

初识Protocol Buffer(Protocol Buffer的下载与安装)

Protocol Buffer的下载安装 Protocol Buffer: 一、简介       Protocol Buffer(以下简称Protobuf)是google 的一种数据交换的格式,它独立...

Delphi7高级应用开发随书源码

  • 2003年04月30日 00:00
  • 676KB
  • 下载

protobuf-2.5.0.tar.gz的下载与安装

1.下载     hadoop使用protocol buffer进行通信,需要下载和安装 protobuf-2.5.0.tar.gz。由于 现在 protobuf-2.5.0.tar.gz已经无...

手把手教你如何安装Protocol Buffer

前言 习惯用 Json、XML 数据存储格式的你们,相信大多都没听过Protocol Buffer Protocol Buffer 其实 是 Google出品的一种轻量 & 高效的结构化数据存储格式,...

Delphi7高级应用开发随书源码

  • 2003年04月30日 00:00
  • 676KB
  • 下载

window8下vs2012 编译和使用protocol buffer

1、下载protocol buffer源码 在百度protocol buffer时,大多数人给的地址都是http://code.google.com/p/protobuf/downloads/list...

windows下使用protobuf

1.下载protobuf https://github.com/google/protobuf/releases 选择protoc-xxx-win32.zip下载 2.将解压出来的p...

【Google Protobuf】windows下protobuf的环境搭建(一)

一、Protobuf介绍   Protobuf是由谷歌开源而来,在谷歌内部久经考验。它将数据结构以.proto文件进行描述,通过代码生成工具可以生成对应数据结构的POJO对象和Protobuf相关的方...

Delphi7高级应用开发随书源码

  • 2003年04月30日 00:00
  • 676KB
  • 下载

protobuf java中的使用

Protobuf在Java中的简单使用   1.      在Java中使用protobuf需要jar包,下载protobuf-Java-2.5.0.jar包文件,添加到项目中。另外需要proto...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:protocolbuffer 在java中的使用 (windows平台)
举报原因:
原因补充:

(最多只允许输入30个字)