• java中compareTo和compare方法之比较


    这两个方法经常搞混淆,现对其进行总结以加深记忆。

    1. compareTo(Object o)方法是java.lang.Comparable<T>接口中的方法,当需要对某个类的对象进行排序时,该类需要实现Comparable<T>接口的,必须重写public int compareTo(T o)方法,比如MapReduce中Map函数和Reduce函数处理的 <key,value>,其中需要根据key对键值对进行排序,所以,key实现了WritableComparable<T>接口,实现这个接口可同时用于序列化和反序列化。WritableComparable<T>接口(用于序列化和反序列化)是Writable接口和Comparable<T>接口的组合;
    2. compare(Object o1,Object o2)方法是java.util.Comparator<T>接口的方法,它实际上用的是待比较对象的compareTo(Object o)方法。

    下面我们写一来看看上面两个方法是怎么用的:

    首先,写一个User类,代码如下:

    public class User implements Comparable<Object>{
        int id;
        String name;
        
        public User(int id,String name){
            this.id = id;
            this.name = name;
        }
        /*
         * Getters and Setters
        */
        public int getId() {
            return id;
        }
        public void setId(int id) {
            this.id = id;
        }
        public String getName() {
            return name;
        }
        public void setName(String name) {
            this.name = name;
        }
           
        @Override
        public int compareTo(Object o) {
            if(this ==o){
                return 0;            
            }
            else if (o!=null && o instanceof User) {   
                User u = (User) o; 
                if(id<=u.id){
                    return -1;
                }else{
                return 1;
            }
        }else{
            return -1;
        }
    }
    }

    接下来,我们写一个测试类Test:

    public class Test{
        //编写Comparator,根据User的id对User进行排序
        private static final Comparator<User> COMPARATOR = new Comparator<User>() {
           public int compare(User o1, User o2) {
               return o1.compareTo(o2);//运用User类的compareTo方法比较两个对象       
          }
       };
        
        public static void main(String[] args) {
            ArrayList<User> student = new ArrayList<User>();
            User user1 = new User(1,"yueliming");
            User user2 = new User(2,"yueliming");
        
            Collections.sort(student, COMPARATOR);//用我们写好的Comparator对student进行排序
            for(int i=0;i<student.size();i++){
                System.out.println(student.get(i).getId());
            }
        }
    }

     

  • 相关阅读:
    ASCII码表
    arm linux 下移植busybox 的tftp
    Makefile中的路径
    Wireshark图解教程(简介、抓包、过滤器)【转载】
    在装有windows跟ubuntu的机器上重新安装windows后修复ubuntu的grub
    在linux里建立一个快捷方式,连接到另一个目录
    ubuntu 迁移部分 / 目录下的存储空间到 /home目录
    /etc/ntp.conf
    ntp 配置 autokey 功能【摘录】
    mips-openwrt-linux-gcc test_usbsw.c -o usbsw 编译问题
  • 原文地址:https://www.cnblogs.com/yueliming/p/3092576.html
Copyright © 2020-2023  润新知