黄色网址大全免费-黄色网址你懂得-黄色网址你懂的-黄色网址有那些-免费超爽视频-免费大片黄国产在线观看

專注Java教育14年 全國咨詢/投訴熱線:400-8080-105
動力節點LOGO圖
始于2009,口口相傳的Java黃埔軍校
首頁 學習攻略 List集合可以排序嗎?

List集合可以排序嗎?

更新時間:2019-08-30 10:36:49 來源:動力節點 瀏覽2781次

  

最近有小伙伴們問小編List集合可以排序嗎?今天動力節點java培訓機構小編專門針對此問題對大家介紹,List集合是可以排序的,List集合排序有兩種方法,下面就隨小編一起看看List集合排序的兩種方法是什么呢?


首先講一下Comparable接口和Comparator接口,以及他們之間的差異。有助于Collections.sort()方法的使用。


  1、Comparable自然規則排序


  //在自定義類Student里面實現Comparable接口,并重寫抽象方法compareTo(Student o);


  //Collections.sort(集合);


先看一個簡單的例子:


 public static void main(String[] args) {  

        Listnums = new ArrayList();  

            nums.add(3);  

            nums.add(5);  

            nums.add(1);  

            nums.add(0);  

            System.out.println(nums);  

            Collections.sort(nums);  

            System.out.println(nums);  



  輸出結果:


  [3, 5, 1, 0]


  [0, 1, 3, 5]


  稍微復雜的List里面放一個復雜的對象


package core.java.collection.collections;  

  

public class User implements Comparable{  

      

    private int score;  

      

    private int age;  

      

    public User(int score, int age){  

        super();  

        this.score = score;  

        this.age = age;  

    }  

  

    public int getScore() {  

        return score;  

    }  

  

    public void setScore(int score) {  

        this.score = score;  

    }  

  

    public int getAge() {  

        return age;  

    }  

  

    public void setAge(int age) {  

        this.age = age;  

    }  

  

    @Override  

    public int compareTo(User o) {  

        int i = this.getAge() - o.getAge();//先按照年齡排序  

        if(i == 0){  

            return this.score - o.getScore();//如果年齡相等了再用分數進行排序  

        }  

        return i;  

    }  

      

}  

  

public static void main(String[] args) {  

        Listusers = new ArrayList();  

        users.add(new User(78, 26));  

        users.add(new User(67, 23));  

        users.add(new User(34, 56));  

        users.add(new User(55, 23));  

        Collections.sort(users);  

        for(User user : users){  

            System.out.println(user.getScore() + "," + user.getAge());  

        }  

}


  輸出結果:


  55,23


  67,23


  78,26


  34,56


  我們會發現sort(List)方法中List中的T必須實現Comparable接口,然后實現compareTo()方法,該方法的返回值0代表相等,正數表示大于,負數表示小于;為什么在簡單例子中沒有看到實現Comparable接口呢?是因為Integer類其實自己已經實現了Comparable接口,Java已經給我們做好了。


  2、Comparator專門規則排序(l臨時排序)


  //新建一個實現了Comparator接口的類,并重寫抽象方法compare(Student o1, Student o2);


  //Collections.sort(集合,實現了Comparator接口的類的實例化對象);


  Collections提供的第二種排序方法sort(Listlist, Comparator c)


  先看例子:


package core.java.collection.collections;  

  

public class Students {  

      

    private int age;  

    private int score;  

      

    public Students(int age, int score){  

        super();  

        this.age = age;  

        this.score = score;  

    }  

      

    public int getAge() {  

        return age;  

    }  

    public void setAge(int age) {  

        this.age = age;  

    }  

    public int getScore() {  

        return score;  

    }  

    public void setScore(int score) {  

        this.score = score;  

    }  

}  

public static void main(String[] args) {  

        Liststudents = new ArrayList();  

        students.add(new Students(23, 100));  

        students.add(new Students(27, 98));  

        students.add(new Students(29, 99));  

        students.add(new Students(29, 98));  

        students.add(new Students(22, 89));  

        Collections.sort(students, new Comparator() {  

  

            @Override  

            public int compare(Students o1, Students o2) {  

                int i = o1.getScore() - o2.getScore();  

                if(i == 0){  

                    return o1.getAge() - o2.getAge();  

                }  

                return i;  

            }  

        });  

        for(Students stu : students){  

            System.out.println("score:" + stu.getScore() + ":age" + stu.getAge());  

        } 

}   


  輸出結果:


  score:89:age22


  score:98:age27


  score:98:age29


  score:99:age29


  score:100:age23


  從上面的例子我們可以看出Students類沒有實現Comparable接口,只是在sort()方法中多傳入一個參數,只不過該參數是一個接口我們需要實現其compare方法。


以上就是動力節點java培訓機構介紹的“List集合可以排序嗎?”的內容,希望能夠幫助到大家,如有疑問,請在線咨詢,有專業老師隨時為你服務。


相關免費視頻教程推薦


List集合可以排序視頻教程下載:http://m.ilovecolors.com.cn/xiazai/2486.html



提交申請后,顧問老師會電話與您溝通安排學習

免費課程推薦 >>
技術文檔推薦 >>
主站蜘蛛池模板: 久操久热| 亚洲国产福利精品一区二区 | 亚洲日本中文字幕在线 | 国产乱人乱精一区二区视频密 | 国产美女一级ba大片免色 | 中文字幕无线码欧美成人 | 欧美成人一区二区三区在线视频 | 青娱乐伊人 | 国产欧美一区二区三区在线 | 成人在线视频观看 | 午夜爱爱网站 | 天天干视频在线观看 | 日韩一区二区视频在线观看 | 丝袜紧身裙国产在线播放 | 黄色α片| 九九99re在线视频精品免费 | 999热成人精品国产免 | 免费一级特黄特色大片在线观看看 | 久草视频在线免费 | 亚洲免费视频网址 | 久久婷婷五月综合色丁香 | www亚洲成人 | 国产精品xxx | 色老头一级毛片 | 欧美奶水 | 国产成人综合亚洲一区 | 中文字幕欧美日韩久久 | 在线 | 一区二区三区四区 | 九九亚洲精品 | 日本乱仑 | 五月综合久久 | 特级毛片视频在线 | 国产欧美日韩第一页 | 天天摸夜夜摸狠狠摸夜夜摸 | 亚洲视频免费播放 | 国产精品免费大片 | 免费的涩涩视频 | 香蕉乱码成人久久天堂爱免费 | 久久久久久久网 | 欧美无内丝袜大尺度福利写真 | 成人小视频免费观看 |