protocolbuffer java_ProtocolBuffer 结合 LZO在 Hadoop中的使用

1.ProtocolBuffer

首先介绍一下ProtocolBuffer吧,可以参考:Protocol Buffer官网

Protocol buffers are a flexible, efficient, automated mechanism for serializing structured data – think XML, but smaller, faster, and simpler. You define how you want your data to be structured once, then you can use special generated source code to easily write and read your structured data to and from a variety of data streams and using a variety of languages. You can even update your data structure without breaking deployed programs that are compiled against the "old" format.

简而言之,就是说Protocol buffers能灵活有效地序列化结构化的数据。

(1)定义消息格式在.proto文件

packagetutorial;

option java_package ="com.example.tutorial";

option java_outer_classname ="AddressBookProtos";

message Person {

required string name =1;

required int32 id =2;

optional string email =3;

enumPhoneType {

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;

}这是一个.proto文件的例子,

这里挺好理解这个文件的,需要说明一下的是,如果不定义java_outer_classname,那么就会只用文件名作为classname,字段分为required,optional和repeated,其中repeated指的是字段可能重复出现,

(2)编译你的Protocol Buffers

1.首先你需要下载安装环境:下载安装

2. 运行如下代码:

protoc -I=$SRC_DIR --java_out=$DST_DIR $SRC_DIR/addressbook.proto这时,你就会得到com/example/tutorial/AddressBookProtos.java类

(3)使用 Java protocol buffer API 去读写消息

// required string name = 1;

publicbooleanhasName();

publicString getName();

// required int32 id = 2;

publicbooleanhasId();

publicintgetId();

// optional string e

mail =3;

publicbooleanhasEmail();

publicString getEmail();

// repeated .tutorial.Person.PhoneNumber phone = 4;

publicList getPhoneList();

publicintgetPhoneCount();

publicPhoneNumber getPhone(intindex);这是相关的字段,分别解析成了java不同的类型,

同时Person.Builder

// required string name = 1;

publicbooleanhasName();

publicjava.lang.String getName();

publicBuilder setName(String value);

publicBuilder clearName();

// required int32 id = 2;

publicbooleanhasId();

publicintgetId();

publicBuilder setId(intvalue);

publicBuilder clearId();

// optional string email = 3;

publicbooleanhasEmail();

publicString getEmail();

publicBuilder setEmail(String value);

publicBuilder clearEmail();

// repeated .tutorial.Person.PhoneNumber phone = 4;

publicList getPhoneList();

publicintgetPhoneCount();

publicPhoneNumber getPhone(intindex);

publicBuilder setPhone(intindex, PhoneNumber value);

publicBuilder addPhone(PhoneNumber value);

publicBuilder addAllPhone(Iterable value);

publicBuilder clearPhone();0b1331709591d260c1c78e86d0c51c18.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值