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

專注Java教育14年 全國(guó)咨詢/投訴熱線:400-8080-105
動(dòng)力節(jié)點(diǎn)LOGO圖
始于2009,口口相傳的Java黃埔軍校
首頁(yè) hot資訊 Java中的各種集合排序

Java中的各種集合排序

更新時(shí)間:2021-05-06 11:39:30 來源:動(dòng)力節(jié)點(diǎn) 瀏覽859次

1.背景

(1)軟件開發(fā)過程中集合排序是比較強(qiáng)大的功能,會(huì)使用集合Map、Set、List實(shí)現(xiàn)排序功能,知道匿名內(nèi)部類Comparator很關(guān)鍵,搞清楚集合排序的性能開銷,排序遇到的坑以及解決的方法,注意下面的例子都是JDK1.8的用法。

2.LIst集合排序

(1)UML類圖

(2)重點(diǎn)分析下ArrayList的排序,畢竟實(shí)戰(zhàn)開發(fā)用的最頻繁的就是它了

3.第一種做法

介紹:這種叫定制排序,或自定義排序,需編寫匿名內(nèi)部類,先new一個(gè)Comparator接口的比較器對(duì)象c,同時(shí)實(shí)現(xiàn)compare()其方法;

然后將比較器對(duì)象c傳給Collections.sort()方法的參數(shù)列表中,實(shí)現(xiàn)排序功能;一般用這種的比較多。

(1)實(shí)體類(private int id)

public class Person{
    private int id;
    private String name;
    private String address; 
    public Person(int id, String name, String address) {
        this.id = id;
        this.name = name;
        this.address = address;
    } 
    public int getId() {
        return id;
    } 
    public void setId(int id) {
        this.id = id;
    } 
    public String getName() {
        return name;
    } 
    public void setName(String name) {
        this.name = name;
    } 
    public String getAddress() {
        return address;
    }
    public void setAddress(String address) {
        this.address = address;
    } 
    @Override
    public String toString() {
        return "Person{" +
                "id='" + id + '\'' +
                ", name='" + name + '\'' +
                ", address='" + address + '\'' +
                '}';
    }
}

(2)測(cè)試類

public class ArrayListTest {
    public static void main(String[] args) {
        List<Person> list=Lists.newArrayList();
        //產(chǎn)生10以內(nèi)的隨機(jī)數(shù)
        int num = (int)(Math.random()*1000+1);
        for(int i=num;i>0;i--){
            list.add(new Person(i,"張三","河南"));
        }
        for(Object o : list){
            System.out.println(o);
        }
        System.out.println("++++++++++++++++++++++++++++++++++++");
        Collections.sort(list, new Comparator<Person>() {
           @Override
           public int compare(Person o1, Person o2) {
               if (o1.getId() > o2.getId()) {
                   return 1;
               } else if (o1.getId() < o2.getId()) {
                   return -1;
               }
               return 0;
           }
       });
        for(Object o : list){
            System.out.println(o);
        }
    }
}

(3)結(jié)果(升序)

Person{id='10', name='張三', address='河南'}
Person{id='9', name='張三', address='河南'}
Person{id='8', name='張三', address='河南'}
Person{id='7', name='張三', address='河南'}
Person{id='6', name='張三', address='河南'}
Person{id='5', name='張三', address='河南'}
Person{id='4', name='張三', address='河南'}
Person{id='3', name='張三', address='河南'}
Person{id='2', name='張三', address='河南'}
Person{id='1', name='張三', address='河南'}
++++++++++++++++++++++++++++++++++++
Person{id='1', name='張三', address='河南'}
Person{id='2', name='張三', address='河南'}
Person{id='3', name='張三', address='河南'}
Person{id='4', name='張三', address='河南'}
Person{id='5', name='張三', address='河南'}
Person{id='6', name='張三', address='河南'}
Person{id='7', name='張三', address='河南'}
Person{id='8', name='張三', address='河南'}
Person{id='9', name='張三', address='河南'}
Person{id='10', name='張三', address='河南'}

4.第二中做法

(1)實(shí)體類(private String id)

public class Person{
    private String id;
    private String name;
    private String address; 
    public Person(String id, String name, String address) {
        this.id = id;
        this.name = name;
        this.address = address;
    } 
    public String getId() {
        return id;
    } 
    public void setId(String id) {
        this.id = id;
    } 
    public String getName() {
        return name;
    } 
    public void setName(String name) {
        this.name = name;
    } 
    public String getAddress() {
        return address;
    } 
    public void setAddress(String address) {
        this.address = address;
    } 
    @Override
    public String toString() {
        return "Person{" +
                "id='" + id + '\'' +
                ", name='" + name + '\'' +
                ", address='" + address + '\'' +
                '}';
    }
}

(2)測(cè)試類

public class ArrayListTest {
    public static void main(String[] args) {
        List<Person> list=Lists.newArrayList();
        //產(chǎn)生10以內(nèi)的隨機(jī)數(shù)
        int num = (int)(Math.random()*100+1);
        for(int i=num;i>0;i--){
            list.add(new Person(""+i,"張三","河南"));
        }
        for(Object o : list){
            System.out.println(o);
        }
        System.out.println("++++++++++++++++++++++++++++++++++++");
       Collections.sort(list, new Comparator<Person>() {
           @Override
           public int compare(Person o1, Person o2) {
               return  new Double(o1.getId()).compareTo(new Double(o2.getId()));
           } 
       });
        for(Object o : list){
            System.out.println(o);
        }
    }
}

(3)結(jié)果

Person{id='10', name='張三', address='河南'}
Person{id='9', name='張三', address='河南'}
Person{id='8', name='張三', address='河南'}
Person{id='7', name='張三', address='河南'}
Person{id='6', name='張三', address='河南'}
Person{id='5', name='張三', address='河南'}
Person{id='4', name='張三', address='河南'}
Person{id='3', name='張三', address='河南'}
Person{id='2', name='張三', address='河南'}
Person{id='1', name='張三', address='河南'}
++++++++++++++++++++++++++++++++++++
Person{id='1', name='張三', address='河南'}
Person{id='2', name='張三', address='河南'}
Person{id='3', name='張三', address='河南'}
Person{id='4', name='張三', address='河南'}
Person{id='5', name='張三', address='河南'}
Person{id='6', name='張三', address='河南'}
Person{id='7', name='張三', address='河南'}
Person{id='8', name='張三', address='河南'}
Person{id='9', name='張三', address='河南'}
Person{id='10', name='張三', address='河南'}

5.第三種做法

另外一種稱為自然排序,參與排序的對(duì)象需實(shí)現(xiàn)comparable接口,重寫其compareTo()方法,方法體中實(shí)現(xiàn)對(duì)象的比較大小規(guī)則。

(1)實(shí)體類

public class Person implements Comparable{
    private String id;
    private String name;
    private String address; 
    public Person(String id, String name, String address) {
        this.id = id;
        this.name = name;
        this.address = address;
    } 
    public String getId() {
        return id;
    } 
    public void setId(String id) {
        this.id = id;
    } 
    public String getName() {
        return name;
    } 
    public void setName(String name) {
        this.name = name;
    } 
    public String getAddress() {
        return address;
    } 
    public void setAddress(String address) {
        this.address = address;
    } 
    @Override
    public String toString() {
        return "Person{" +
                "id='" + id + '\'' +
                ", name='" + name + '\'' +
                ", address='" + address + '\'' +
                '}';
    } 
    @Override
    public int compareTo(Object o) {
        if (o instanceof Person){
            Person o1 = (Person)o;
            return  new Double(this.getId()).compareTo(new Double(o1.getId()));
        }
        throw new ClassCastException("不能轉(zhuǎn)換為Person類型的對(duì)象...");
    }
}

(2)測(cè)試類

public class ArrayListTest {
    public static void main(String[] args) {
        List<Person> list=Lists.newArrayList();
        //產(chǎn)生10以內(nèi)的隨機(jī)數(shù)
        int num = (int)(Math.random()*100+1);
        for(int i=num;i>0;i--){
            list.add(new Person(""+i,"張三","河南"));
        }
        for(Object o : list){
            System.out.println(o);
        }
        System.out.println("++++++++++++++++++++++++++++++++++++");
        Collections.sort(list);
        for(Object o : list){
            System.out.println(o);
        }
    }
}

(3)結(jié)果

Person{id='10', name='張三', address='河南'}
Person{id='9', name='張三', address='河南'}
Person{id='8', name='張三', address='河南'}
Person{id='7', name='張三', address='河南'}
Person{id='6', name='張三', address='河南'}
Person{id='5', name='張三', address='河南'}
Person{id='4', name='張三', address='河南'}
Person{id='3', name='張三', address='河南'}
Person{id='2', name='張三', address='河南'}
Person{id='1', name='張三', address='河南'}
++++++++++++++++++++++++++++++++++++
Person{id='1', name='張三', address='河南'}
Person{id='2', name='張三', address='河南'}
Person{id='3', name='張三', address='河南'}
Person{id='4', name='張三', address='河南'}
Person{id='5', name='張三', address='河南'}
Person{id='6', name='張三', address='河南'}
Person{id='7', name='張三', address='河南'}
Person{id='8', name='張三', address='河南'}
Person{id='9', name='張三', address='河南'}
Person{id='10', name='張三', address='河南'}

以上就是動(dòng)力節(jié)點(diǎn)小編介紹的"Java中的各種集合排序"的內(nèi)容,希望對(duì)大家有幫助,如有疑問,請(qǐng)?jiān)诰€咨詢,有專業(yè)老師隨時(shí)為您服務(wù)。

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

免費(fèi)課程推薦 >>
技術(shù)文檔推薦 >>
主站蜘蛛池模板: 日韩欧美久久一区二区 | 中文字幕 亚洲 一区二区三区 | 成人超污免费网站在线看 | 国产亚洲精品福利在线 | 日韩免费高清一级毛片久久 | 黄色的视频免费观看 | 7m凹凸国产刺激在线视频 | 最近的2019中文字幕7 | 国产日产精品_国产精品毛片 | 午夜爱爱网站 | 天天爽夜夜爽人人爽免费 | 国产高清天干天天视频 | 国产人成午夜免费噼啪视频 | 日日碰日日摸日日澡视频播放 | 国产黄色大片网站 | 欧美成人高清视频 | 日韩精品视频免费在线观看 | 黄色免费在线观看 | 日韩在线国产精品 | a级黄色毛片视频 | 成人免费在线观看网站 | 放荡的美妇一区二区三区 | 日韩一级欧美一级在线观看 | 色诱久久av | 黄色片黄色片黄色片黄色片黄色片 | 污视频网站在线观看免费 | 狠狠色狠狠色综合日日五 | 亚洲欧美日韩在线观看二区 | 久草操| 毛片无限看 | 一级国产在线观看高清 | 在线看国产精品 | 国产成人综合在线观看 | 欧美顶级xxxxbbbb | 久草看片| 2018天天干夜夜操 | 国产片18在线观看 | 成人黄网18免费观看的网站 | xxxx日日摸夜夜添夜夜添视频 | 亚洲一级黄色片 | 日韩18视频在线观看 |