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

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

List集合可以排序嗎?

更新時(shí)間:2019-08-30 10:36:49 來源:動力節(jié)點(diǎn) 瀏覽2778次

  

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


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


  1、Comparable自然規(guī)則排序


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


  //Collections.sort(集合);


先看一個(gè)簡單的例子:


 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);  



  輸出結(jié)果:


  [3, 5, 1, 0]


  [0, 1, 3, 5]


  稍微復(fù)雜的List里面放一個(gè)復(fù)雜的對象


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();//如果年齡相等了再用分?jǐn)?shù)進(jìn)行排序  

        }  

        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());  

        }  

}


  輸出結(jié)果:


  55,23


  67,23


  78,26


  34,56


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


  2、Comparator專門規(guī)則排序(l臨時(shí)排序)


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


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


  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());  

        } 

}   


  輸出結(jié)果:


  score:89:age22


  score:98:age27


  score:98:age29


  score:99:age29


  score:100:age23


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


以上就是動力節(jié)點(diǎn)java培訓(xùn)機(jī)構(gòu)介紹的“List集合可以排序嗎?”的內(nèi)容,希望能夠幫助到大家,如有疑問,請?jiān)诰€咨詢,有專業(yè)老師隨時(shí)為你服務(wù)。


相關(guān)免費(fèi)視頻教程推薦


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



提交申請后,顧問老師會電話與您溝通安排學(xué)習(xí)

免費(fèi)課程推薦 >>
技術(shù)文檔推薦 >>
主站蜘蛛池模板: 最近免费中文字幕完整4 | 欧美日本免费观看αv片 | 天天草天天干天天 | 男女羞羞视频 | 人人射人人 | 国产一区视频在线免费观看 | 777毛片 | 国产欧美日韩在线 | 欧美最新一区二区三区四区 | 国产精品人成在线播放新网站 | 91麻豆精品一二三区在线 | 国产成人精品久久一区二区三区 | 午夜视频在线观看视频 | 日韩三级免费观看 | 国产1级毛片 | 黄色一极毛片 | 美女黄网站 | 久久综合成人网 | 日韩一本 | 日本一区免费 | 国产日韩欧美中文字幕 | 不卡视频一区 | 欧美一级片网址 | 手机在线看片不卡中文字幕 | jizzjizz日本护士水多 | 国产精品欧美日韩视频一区 | 欧美精品hdvideosex | 亚洲国产精品ⅴa在线观看 亚洲国产精品成人久久 | 亚洲第一免费网站 | 一级毛片在线完整免费观看 | 婷婷综合久久狠狠色99h | 亚洲欧美日韩久久精品第一区 | 国产一级片播放 | 东方aⅴ免费观看久久av | 万部在线视频免费观看 | 亚洲欧美高清视频 | 免看黄 | 91欧洲在线视精品在亚洲 | 看全色黄大色黄大片女图片 | 欧美综合影院 | 日本不卡视频在线 |