20191121 比较器Comparator

本文深入探讨了Java中的排序机制,重点讲解了Comparable接口及其compareTo方法在排序中的应用,同时介绍了如何利用Comparator接口进行自定义排序,以及HashMap根据value值进行排序的具体实现。

Comparable比较器类,主要用于排序。

在字符串中使用过CompareTo方法,这个方法是用于比较字符串顺序的,根据字典顺序进行排序。

Java中所有的compareTo方法都源于一个共同的接口,那就是Comparable。这个接口只有一个方法,那就是CompareTo。所有想要具有比较功能的类,都建议实现这个接口,而非是自己定义这个功能。

 

    /**
     * HashMap根据value值进行排序
     */
    private static void valueSort() {
        HashMap<String, Integer> map = new HashMap<>();
        map.put("网二",1);
        map.put("张三",2);
        map.put("赵四",3);
        map.put("小柒",4);
        System.out.println("排序前");
        Set<Map.Entry<String, Integer>> entries = map.entrySet();
        for (Map.Entry<String, Integer> entry: entries) {
            System.out.println(entry.getKey()+"--"+entry.getValue());
        }
        System.out.println("排序后");
        ArrayList<Map.Entry<String, Integer>> list = new ArrayList<>(map.entrySet());
        Collections.sort(list, new Comparator<Map.Entry<String, Integer>>() {
            @Override
            public int compare(Map.Entry<String, Integer> o1, Map.Entry<String, Integer> o2) {
                //具体排序规则
                //按照value值,从小到大排序。o1与o2对象的位置
                //return o1.getValue()-o2.getValue();

                //按照value值,从大到小排序
                //return o2.getValue()-o1.getValue();

                //按照key值,用compareTo()方法默认是从小到大排序
                //a按照字典顺序排列
                return o1.getKey().compareTo(o2.getKey());
            }
        });
        for (Map.Entry s : list) {
            System.out.println(s.getKey()+"--"+s.getValue());
        }
    }

1.compareTo(Object obj)方法是java.lang.Comparable接口中的方法; 当需要对类的对象进行排序时,该类需要实Comparable接口,必须重写public int compareTo(T)方法。对对象进行排序。

String类等一些类默认实现了该接口;

String类默认实现了该接口 compareTo()方法的返回值 s1.compareTo(s2)—>s1 与 s2 的ASC码的差值,其实就是字典排序;

2.compare(Object o1, Object o2)方法是java.util.Comparator接口的方法, 它实际上用的是待比较对象的compareTo(Object obj)方法;

3.arrayList排序时   Collections.sort(list) 会自动调用User实现的Comparable的compareTo()方法

4.Collections.sort(list, comparator)//也可以重新实现排序的方法

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值