Protocol Buffer Java实例
大家要先下载protobuffer,在这里:
https://code.google.com/p/protobuf/downloads/list
注意,需要下载两个,一个是complier,另外一个是source code (我下载的是2.5的版本);
讲complier对应的 protoc.exe 拷贝至 source code 对应的./protobuf-2.5.0/src目录下(mvn 编译需要);
cd 到 ./protobuf-2.5.0/java 目录, 执行 mvn clean package 命令打包;
到target目录获取生成的protobuf-java-2.5.0.jar包(Java代码对protobuf依赖的jar包);
person.proto文件
package com.shine.pb;
option java_package = "com.shine.pb.person";
option java_outer_classname = "MyPerson"; message Person {
required int32 id = 1;
required string name = 2;
optional string email = 3; enum PhoneType {
MOBILE = 0;
FIXED = 1;
} message PhoneInfo {
required string number = 1;
required PhoneType type = 2 [default=MOBILE];
} optional PhoneInfo phone = 4;
}
到protoc.exe所在目录,执行 protoc --java_out=./output/java ./messages/MyMessage.proto
可生成proto文件对应的Java类;
copy到自己eclipse对应src后;写main方法测试,代码如下:
package com.shine.pb.person; import com.google.protobuf.InvalidProtocolBufferException;
import com.shine.pb.person.MyPerson.Person.PhoneType; public class Test { public static void main(String[] args) throws InvalidProtocolBufferException {
MyPerson.Person.Builder builder = MyPerson.Person.newBuilder();
builder.setId(1);
builder.setName("shine");
builder.setEmail("chenguodong@baidu.com");
MyPerson.Person.PhoneInfo.Builder phoneInfoBuilder = MyPerson.Person.PhoneInfo.newBuilder();
phoneInfoBuilder.setNumber("13899999999");
phoneInfoBuilder.setType(PhoneType.MOBILE);
builder.setPhone(phoneInfoBuilder.build()); MyPerson.Person shine = builder.build(); System.out.println(shine.getSerializedSize());
System.out.println(shine.getEmail());
System.out.println(shine.getName());
System.out.println(shine.getPhone().getNumber()); System.out.println("============================================="); byte[] data = shine.toByteArray();
builder = MyPerson.Person.newBuilder();
MyPerson.Person person = MyPerson.Person.parseFrom(data);
System.out.println(person.getSerializedSize());
System.out.println(person.getEmail());
System.out.println(person.getName());
System.out.println(person.getPhone().getNumber());
} }
Protocol Buffer Java实例的更多相关文章
- [翻译]Protocol Buffer 基础: C++
		
目录 Protocol Buffer Basics: C++ 为什么使用 Protocol Buffers 在哪可以找到示例代码 定义你的协议格式 编译你的 Protocol Buffers Prot ...
 - Protocol Buffer技术详解(Java实例)
		
Protocol Buffer技术详解(Java实例) 该篇Blog和上一篇(C++实例)基本相同,只是面向于我们团队中的Java工程师,毕竟我们项目的前端部分是基于Android开发的,而且我们研发 ...
 - Protocol Buffer序列化Java框架-Protostuff
		
了解Protocol Buffer 首先要知道什么是Protocol Buffer,在编程过程中,当涉及数据交换时,我们往往需要将对象进行序列化然后再传输.常见的序列化的格式有JSON,XML等,这些 ...
 - Protocol Buffer技术详解(C++实例)
		
Protocol Buffer技术详解(C++实例) 这篇Blog仍然是以Google的官方文档为主线,代码实例则完全取自于我们正在开发的一个Demo项目,通过前一段时间的尝试,感觉这种结合的方式比较 ...
 - Protocol Buffer序列化对比Java序列化.
		
初识 Protocol Buff是谷歌推出的一种序列化协议. 而Java序列化协议也是一种协议. 两者的目的是, 将对象序列化成字节数组, 或者说是二进制数据, 那么他们之间有什么差异呢. proto ...
 - Protocol Buffer序列化/反序列化---初体验(java版)
		
今天闲遐时学习了 Protocol Buffer 在网上看到了许多资料,其中不泛精品,想要详细了解的请看文章结尾的友情链接,我这里就做加深印象,快速入门的一个完整的demo,仅此而已. 学完你可以得到 ...
 - Java与C++进行系统间交互:Protocol Buffer
		
在一次项目中,因笔者负责的java端应用需要与公司C++系统进行交互,公司选定Protocol Buffer方案,故简单的了解一下 有需要的可以看一下其他作者的文章,了解一下Protobuf: htt ...
 - Protocol Buffer使用转换工具将proto文件转换成Java文件流程及使用
		
Client与Server的网络通信协议传输使用google protobuf,服务器端使用的是Java 一. Protocol Buffersprotobuf全称Google Protocol Bu ...
 - 后端程序员之路 39、一个Protocol Buffer实例
		
实际工作的Protocol Buffer使用经验 # 写proto文件- 协议版本 项目用的是protobuf2,所以要指定 syntax = "proto2";- 包名 pack ...
 
随机推荐
- OpenFlow Switch学习笔记(三)——Flow Tables
			
这次我们主要讨论下OpenFlow Switch的核心组件之一——Flow Tables,以了解其内部的 matching 以及 action handling 机制.下文将会分为几个部分来逐步详述O ...
 - js实现简单易用的上下无缝滚动效果
			
<!doctype html> <html> <head> <meta charset="utf-8"> <title> ...
 - iOS学习笔记---c语言学习第七天
			
结构体 结构体是一种自定义的数据类型 struct 结构体名 { 类型说明符 成员名: … 类型说明符 成员名: }: #import <Foundation/Foundation.h& ...
 - JS初学之-效果没出来怎么办?-alert函数测试
			
一般出了问题之后,有经验的高手一眼就可以看出来,但是对于我们初学者来说,利用alert函数不失为一个好方法. 这时我们要利用逐行测试的方法,在任意一句代码下加alert,如果可以弹出来就说明上面的没有 ...
 - Baxter机器人---Hello_baster(二)
			
原创博文,转载请标明出处:--周学伟http://www.cnblogs.com/zxouxuewei/ Step 1: Setup ROS Environment root@zxwubuntu-As ...
 - MySQL日志功能
			
1.查询日志 log={ON|OFF}:是否记录所有语句的日志信息于一般查询日志文件(general_log); log_output={TABLE|FILE|NONE},TABLE和FILE可以同时 ...
 - Linux系统编程@进程管理(二)
			
1.创建守护进程(Deamon) 守护进程的概念与作用 后台服务程序 – 系统服务,进程名字往往以’d’结尾,生存周期比较长(系统装入时启动,关闭时候终止.系统装入两种启动方式:1从启动脚本.etc/ ...
 - js获取客户端操作系统
			
function detectOS() { var sUserAgent = navigator.userAgent; var isWin = (navigator.platform == " ...
 - Twitter 登录和分享
			
继上面一片介绍了FaceBook的登录和分享,现在再来实现Twitter的登录和分享. 1.首先要说明的是,我没找到官方提供的SDK,查阅很多文章都提到了一个帮助实现的包Twitter4j.jar ...
 - 016. asp.net的验证控件
			
RequiredFileldValidator: 检查某个字段是否输入; 空值检查 主要属性: ControlToValidate:要验证的控件 ErrorMessage:错误提示信息 Compare ...