<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    Ordinary hut

    人間一福地,勝似天仙宮
    posts - 61, comments - 50, trackbacks - 0, articles - 1

    java中Collections.sort() 排序函數(shù)的用法

    Posted on 2009-04-07 16:40 landor 閱讀(164678) 評論(7)  編輯  收藏 所屬分類: java
    用Collections.sort方法對list排序有兩種方法
    第一種是list中的對象實現(xiàn)Comparable接口,如下:
    /**
    * 根據(jù)order對User排序
    */
    public class User implements Comparable<User>{
        
    private String name;
        
    private Integer order;
        
    public String getName() {
            
    return name;
        }
        
    public void setName(String name) {
            
    this.name = name;
        }
        
    public Integer getOrder() {
            
    return order;
        }
        
    public void setOrder(Integer order) {
            
    this.order = order;
        }
        
    public int compareTo(User arg0) {
            
    return this.getOrder().compareTo(arg0.getOrder());
        }
    }
    測試一下:
    public class Test{

        
    public static void main(String[] args) {
            User user1 
    = new User();
            user1.setName(
    "a");
            user1.setOrder(
    1);
            User user2 
    = new User();
            user2.setName(
    "b");
            user2.setOrder(
    2);
            List
    <User> list = new ArrayList<User>();
            
    //此處add user2再add user1
            list.add(user2);
            list.add(user1);
            Collections.sort(list);
            
    for(User u : list){
                System.out.println(u.getName());
            }
        }
    }
    輸出結(jié)果如下
    a
    b

    第二種方法是根據(jù)Collections.sort重載方法來實現(xiàn),例如:
    /**
    * 根據(jù)order對User排序
    */
    public class User { //此處無需實現(xiàn)Comparable接口
        private String name;
        
    private Integer order;
        
    public String getName() {
            
    return name;
        }
        
    public void setName(String name) {
            
    this.name = name;
        }
        
    public Integer getOrder() {
            
    return order;
        }
        
    public void setOrder(Integer order) {
            
    this.order = order;
        }
    }

    主類中這樣寫即可:
    public class Test{
        
    public static void main(String[] args) {
            User user1 
    = new User();
            user1.setName(
    "a");
            user1.setOrder(
    1);
            User user2 
    = new User();
            user2.setName(
    "b");
            user2.setOrder(
    2);
            List
    <User> list = new ArrayList<User>();
            list.add(user2);
            list.add(user1);
           
            Collections.sort(list,
    new Comparator<User>(){
                
    public int compare(User arg0, User arg1) {
                    
    return arg0.getOrder().compareTo(arg1.getOrder());
                }
            });
            
    for(User u : list){
                System.out.println(u.getName());
            }
        }
    }
    輸出結(jié)果如下
    a
    b

    前者代碼結(jié)構(gòu)簡單,但是只能根據(jù)固定的屬性排序,后者靈活,可以臨時指定排序項,但是代碼不夠簡潔

    擇優(yōu)用之。

    Feedback

    # re: java中Collections.sort()函數(shù)的用法  回復(fù)  更多評論   

    2009-04-07 16:44 by 沙鑫
    不錯啊`~~學(xué)習(xí)

    # re: java中Collections.sort()函數(shù)的用法  回復(fù)  更多評論   

    2010-02-02 13:22 by gongmingwind
    Collections這個工具類,很強大,寫的不錯,支持你

    # re: java中Collections.sort() 排序函數(shù)的用法[未登錄]  回復(fù)  更多評論   

    2010-05-21 14:47 by w
    搞個可構(gòu)造方法就方便看

    # re: java中Collections.sort() 排序函數(shù)的用法[未登錄]  回復(fù)  更多評論   

    2014-12-03 14:56 by conjs
    簡之。。。
    List<User> list = Lists.newArrayList(new User(1,"a"),new User(2,"b"));
    Collections.sort(list,(User a,User b)->(a.getOrder().compareTo(b.getOrder()));
    print(list);

    # re: java中排序函數(shù)的用法  回復(fù)  更多評論   

    2016-03-21 15:53 by Collections.sort()
    分Collections.sort()

    # re: java中Collections.sort() 排序函數(shù)的用法  回復(fù)  更多評論   

    2016-04-01 15:18 by 任起東
    接口可以被實例化????

    # re: java中Collections.sort() 排序函數(shù)的用法[未登錄]  回復(fù)  更多評論   

    2016-07-13 19:55 by ff
    @任起東 實際上是java生成了一個類出來。
    主站蜘蛛池模板: 国产成人综合亚洲亚洲国产第一页| 国产精品免费大片| 精品久久洲久久久久护士免费 | 2019中文字幕在线电影免费| 亚洲精品无码久久千人斩| 精品久久久久久无码免费| 亚洲爽爽一区二区三区| 好湿好大好紧好爽免费视频| 亚洲欧洲成人精品香蕉网| 成人影片一区免费观看| 亚洲欧洲美洲无码精品VA| 久久精品视频免费播放| 久久精品国产亚洲AV大全| 日本三级2019在线观看免费| 亚洲偷自精品三十六区| 国产精品无码一二区免费| 免费无码一区二区| 黑人精品videos亚洲人| 美丽的姑娘免费观看在线播放| 亚洲国产成人综合| 日美韩电影免费看| 伊人久久国产免费观看视频| 亚洲AV无码一区二区三区系列| 免费观看激色视频网站bd | 亚洲v高清理论电影| 18禁止观看免费私人影院| 8888四色奇米在线观看免费看| 亚洲欧洲校园自拍都市| 久久久免费的精品| 亚洲一级毛片免费观看| 久久久久久亚洲精品| 97人妻无码一区二区精品免费| 亚洲av日韩精品久久久久久a| 亚洲 另类 无码 在线| 一级毛片免费观看| 日韩色日韩视频亚洲网站 | 国产亚洲日韩在线三区| 久久免费看黄a级毛片 | 久久久高清日本道免费观看| 亚洲成电影在线观看青青| 又爽又黄无遮挡高清免费视频|