集合排序

<small>

集合排序

可以直接通过集合工具类,Collections中的sort( )方法进行排序
collections中的sort排序规则是按照自然排序规则实现的
static sort() 静态方法,无需返回值

  1. 英文字母按照ascii码排序
  2. 数字按照阿拉伯顺序排序
    注意:集合中的元素想要实现排序功能,则集合元素对应的类型,必须是可比较的
List<String> list1 = 
                    new ArrayList<String>();
        list1.add("梅川酷子");
        list1.add("程承");
        list1.add("阿百川");
        list1.add("丁");
        System.out.println("原集合:"+list1);
        Collections.sort(list1);

当集合中的元素是自定的people类时:

List<People> list3 = 
                new ArrayList<People>();
        list3.add(new People("程咬金",118));
        list3.add(new People("关羽",20));
        list3.add(new People("西门吹雪",39));
        System.out.println("原集合:"+list3);
    
    Collections.sort(list3);

这时候需要对people中的comparTo方法进行重写

    @Override
    public int compareTo(People other) {
        /*
         * 可比较规则:
         *  比较的是人的年龄,按年龄大小自然排序。
         *  
         *  无需关心比较计算的具体结果,原则:
         *      结果 > 0,说明:this.age > other.age
         *      结果 = 0,说明:this.age = other.age
         *      结果 < 0,说明:this.age < other.age
         *  自然排序,大的后移。
         * 
         *  顺序排序:this对象在前,other对象在后。
         *  倒序排序:other对象在前,this对象在后。
         */
        return //this.age - other.age;//顺序排序
                other.age - this.age;//倒序排序

当这种自然排序不符合业务需求的时候,需要借助到比较器

@Override
    public int compare(People peo1, People peo2) {
        return peo1.name.length() - peo2.name.length();
    }

如果是非自定义的类,例如string无法实现接口的时候,需要通过匿名内部类来实现:

List<String> list1 = 
                new ArrayList<String>();
        list1.add("梅川酷子");
        list1.add("程承");
        list1.add("阿百川");
        list1.add("丁");
        System.out.println("原集合:"+list1);
        /*
         * String类的中可比较接口,是按字符串的字典顺序排序。
         *  如何按照字符串中的字母个数顺序排序?
         * 
         * 当自然排序规则,满足不了业务需求时,
         *  可以直接通过另一种比较规则:
         *      自定义比较器比较规则,通过自定义规则
         *      来完成集合元素排序。
         * 
         * 比较器:
         *  也是一个接口,实现Comparator,重写compare方法。
         * 
         * Collections.sort(List list) 一个集合参数,
         *      只会按照元素的自然排序(Comparable的)规则。
         * 
         * Collections.sort(List list,Comparator) 
         *      集合、比较器两个参数
         *      会按照比较器(Comparator的)中自定义定义的
         *      规则,来完成排序。
         *  
         */
//      Collections.sort(list1);//自然排序
        Comparator<String> stringComparator = 
                new Comparator<String>(){
            @Override
            public int compare(String str1, String str2) {
                return str1.length() - str2.length();
            }
            
        };
        Collections.sort(list1,stringComparator);//自定义排序
        System.out.println("排序之后的集合:"+list1);

总结:

1、必须要求元素类型为可比较类型
2、对于API常见类,都是按照自然排序规则实现的
当已有的排序规则满足不了排序规则时,考虑到自定义排序规则,排序规则有两种实现:
a、实现可比较接口,重写compareTo方法
b、实现比较器接口,重写compare方法
3、自定义类,上述两种规则都可以实现
class 类名 implements Comparable<类名>,comparator<类名>
4、非自定义类,如果没有排序规则,只能通过匿名内部类方式,创建可比较器对象,再通过Collections.sort(集合,比较器),此方法才能实现排序

comparable(可比较接口)与comparator(比较器接口)比较

1、comparable(可比较接口)自然排序规则,重写compareTo方法,定好规则,不会发生改变,Collections.sort(),实现自然排序
2、comparator(比较器接口)自定义排序规则,重写compare方法,规则经常发生改变,Collections.sort(集合,比较器),实现自定义排序
3、自定义类中:两种接口都可以直接实现,一般comparable是通过实现方式完成,已近实现自然排序规则,但自然排序规则满足不了业务需求,需要通过匿名内部类的方式,创建comparator比较器对象,通过Collections.sort完成排序,或者没有实现自然排序规则也可以通过这种方法来完成排序

结论:使用匿名内部类来创建比较器规则是最常用的排序方法

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,921评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,635评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,393评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,836评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,833评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,685评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,043评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,694评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 42,671评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,670评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,779评论 1 332
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,424评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,027评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,984评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,214评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,108评论 2 351
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,517评论 2 343

推荐阅读更多精彩内容

  • Java API提供了两种方法来排序: 一、Collections.sort(List list) 使用此API排...
    RaphetS阅读 4,765评论 1 10
  • 2016.7.26 以我的理解来看Comparable接口是一个直接在实例类里实现的接口,实现后就能支持Colle...
    云转水流阅读 214评论 0 0
  • 集合排序 要么让集合的对象具有比较性也就是让集合中的对象实现Comparable<T>接口 自定义比较器实现Com...
    亮之于东阅读 304评论 0 0
  • 1.Java集合框架是什么?说出一些集合框架的优点?每种编程语言中都有集合,最初的Java版本包含几种集合类:Ve...
    yjaal阅读 1,175评论 1 10
  • 古老的东方有条龙 传说这条龙很英雄 五湖四海展雄风 这条神奇而伟大的英雄龙 就是我们中国龙 自强不息的中华儿女 都...
    秋AldrichB果阅读 419评论 0 13