MapReduce自定义数据类型

    Mapreduce有基本数据类型Text,IntWritable...,也可以由我们自定义数据类型。我们自定义数据类型需要实现接口WritableComparable,基本数据类型也是实现了这个接口。

下面是接口WritableComparable的源码

public interface WritableComparable<T> extends Writable, Comparable<T> {
}

可以看到接口WritableComparable继承了两个接口,而自己并没有实现任何方法。

下面是Writable接口的源码

public interface Writable {
  void write(DataOutput out) throws IOException;
  void readFields(DataInput in) throws IOException;
}

可以看到Writable接口中有两个方法,下面看Comparable接口

public interface Comparable<T> {
    public int compareTo(T o);
}

这个接口只有一个方法,所以继承自WritableComoarable的类需要实现三个方法,参照如下:

public class MyWritableComparable implements WritableComparable<MyWritableComparable> {
 *       private int counter;
 *       private long timestamp;
 *       
 *       public void write(DataOutput out) throws IOException {
 *         out.writeInt(counter);
 *         out.writeLong(timestamp);
 *       }
 *       
 *       public void readFields(DataInput in) throws IOException {
 *         counter = in.readInt();
 *         timestamp = in.readLong();
 *       }
 *       
 *       public int compareTo(MyWritableComparable o) {
 *         int thisValue = this.value;
 *         int thatValue = o.value;
 *         return (thisValue < thatValue ? -1 : (thisValue==thatValue ? 0 : 1));
 *       }
 *
 *       public int hashCode() {
 *         final int prime = 31;
 *         int result = 1;
 *         result = prime * result + counter;
 *         result = prime * result + (int) (timestamp ^ (timestamp >>> 32));
 *         return result
 *       }
 *     }


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值