----------------------compareTo(BaseDimension o) 方法的使用--------------------------

虽然Hadoop MapReduce框架为我们提供了很多key类型,但是有些时候,MapReduce过程中的Key很复杂,需要考虑到多个维度的变化,从而导致key并不完全符合Hadoop提供的原生类型,比如说Text(对应Java中的String,)、LongWritable(对应Java中的long)等。所以我们就需要自定义Hadoop MapReduce过程中的key类型。根据这个基类去比较key,我们所需要定义的类必须实现WritableComparable这个类。

01.key是用来进行相互比较,从而达到排序的目的。
02.WritableComparable类实现了Writable(实现的类可序列化) 和Comparable(实现的类可比较)接口。

 

代码说明:

public int compareTo(Object o) {
//把Object o转成Name型,便于比较
Name n = (Name)o;
//我们Name怎么比大小呢?那就直接比比我们的lastName吧,
//怎么比,直接用String的compareTo方法好了,java写好的,不用白不用
int lastCmp = lastName.compareTo(n.lastName);
//看看吧如果lastName比出结果了,那最好罗,如果比出来一样咋办?那我们再比比firstName吧
return
(lastCmp != 0 ? lastCmp : firstName.compareTo(n.firstName));  
}  

 

代码说明:

@Override
public int compareTo(BaseDimension o) {
if(this==o) {  //如果当前的类中的对象和传入的对象  == 相等返回0 true
return 0;
}

PlatformDimension other=(PlatformDimension)o;    //把BaseDimension o转成PlatformDimension型,便于比较
int temp=0;
   temp=Integer.compare(this.id, other.getId());  //int 类型的比较   Integer.compare(this.id, other.getId())   当前类中的Id 和传入的id 比较
if(temp!=0) {
return temp;
}
return this.platform_name.compareTo(other.getPlatform_name());
}

 

转载于:https://www.cnblogs.com/helloaugust/p/11020727.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值