zoukankan      html  css  js  c++  java
  • ----------------------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());
    }

  • 相关阅读:
    kNN之手写数字识别
    KNN 约会网站配对
    mask_rcnn训练自己的数据集
    Unable to determine the device handle for GPU 0000:01:00.0: GPU is lost.问题排坑
    PAT Advanced 1050 String Subtraction (20) [Hash散列]
    PAT Advanced 1048 Find Coins (25) [Hash散列]
    PAT Advanced 1041 Be Unique (20) [Hash散列]
    PAT Basic 1083 是否存在相等的差 (20) [hash映射,map STL]
    PAT Basic 1047 编程团体赛(20) [Hash散列]
    PAT Basic 1043 输出PATest (20分)[Hash散列]
  • 原文地址:https://www.cnblogs.com/helloaugust/p/11020727.html
Copyright © 2011-2022 走看看