Java排序类-Collections.sort()的使用

使用背景
        LinkedList<MyData> list=new LinkedList<>();
        list.add(new MyData(1995,10,4,12));
        list.add(new MyData(1999,9,4,10));
        list.add(new MyData(1999,12,3,15));
        list.add(new MyData(1996,1,3,15));
        list.add(new MyData(1997,2,3,15));
        list.add(new MyData(1997,3,3,15));

如以上,实体类里的属性有不同的权重,如年、月、日,我们需要通过权重大小将list中的对象排序。

第一步

调用Collections.sort();

        LinkedList<MyData> list=new LinkedList<>();
        list.add(new MyData(1995,10,4,12));
                          ...
        list.add(new MyData(1997,3,3,15));

        //排序函数在此调用
        Collections.sort(list);
第二步

将list中的实体类继承Comparable接口,并且重写里面的
--①toString方法(用来测试时输出)
--②compareTo方法(用来比较大小)

public class MyData implements Comparable<MyData>{
    private int y = 0;
    private int m = 0;
    private int d = 0;
        ...//构造函数、Getter、Setter方法

    @Override
    //重写toString方法,用来输出
    public String toString(){
        return "年:"+this.getY()+"  月:"+this.getM()+"  日:"+this.getD();
    }
    @Override
    //重写compareTo方法,用来比较
    public int compareTo(@NotNull MyData o) {
          ...//核心内容在下面
    }
第三步

compareTo方法的内容(核心内容)
-先比较权重最大的属性(年)
--如果当前属性(年)比形参类属性(年)大,则 return 1;
--如果当前属性(年)和形参类属性(年)相等
----则再比较权重第二的属性(月)
--如果当前属性(年)比形参类属性(年)小,则 return -1;
依次类推,比较完年,再比较月,再比较日,如此可得出谁大谁小。
还会有相同的情况,则 return 0;

    @Override
    public int compareTo(@NotNull MyData o) {
        //tmp的作用是比较
        int tmp;
        // 先比较权重最大的,也就是年
        tmp=this.getY()-o.getY();
        if (tmp>0){
            return 1;
        }else if (tmp==0){
            //此时年相等,则比较月份
            tmp=this.getM()-o.getM();
            if (tmp>0){
                return 1;
            }else if (tmp==0){
                //此时年、月都相等,则比较日期
                tmp=this.getD()-o.getD();
                if (tmp>0){
                    return 1;
                }else if (tmp==0){
                    //此时年、月、日都相等
                    return 0;
                }else {
                    return -1;
                }
            }else {
                return -1;
            }
        }else {
            return -1;
        }

    }

以上就是核心用法了!

第四步

简单的输出测试一下

                ...
        Collections.sort(list);
        for (MyData m : list) {
            System.out.println(m.toString());
        }

控制台结果

年:1995  月:10  日:4
年:1996  月:1  日:3
年:1997  月:2  日:3
年:1997  月:3  日:3
年:1999  月:9  日:4
年:1999  月:12  日:3
Process finished with exit code 0

小小小总结

写的很啰嗦,但是功能还是可以实现的,不必纠结于当前类到底是谁,java自有比较的方法,其实只要在重写的compareTo方法里写好,两者比较时的规则就可以了。当调用这个方法时,通过返回值来判断比较的结果,而方法里需要重写的就是比较的具体情况和相应的返回值。

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 从三月份找实习到现在,面了一些公司,挂了不少,但最终还是拿到小米、百度、阿里、京东、新浪、CVTE、乐视家的研发岗...
    时芥蓝阅读 42,373评论 11 349
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,769评论 18 399
  • 国家电网公司企业标准(Q/GDW)- 面向对象的用电信息数据交换协议 - 报批稿:20170802 前言: 排版 ...
    庭说阅读 11,184评论 6 13
  • 一、基本数据类型 注释 单行注释:// 区域注释:/* */ 文档注释:/** */ 数值 对于byte类型而言...
    龙猫小爷阅读 4,291评论 0 16
  • 从小就一直都挺喜欢画画的,尤其偏爱画古风的各种人,不过没有正经去学。花爸妈的钱报班还是觉得太贵,于是就自己先临摹学...
    余一一阅读 770评论 8 9