<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中文字幕免费| 成年人在线免费观看| 91亚洲导航深夜福利| 日韩在线视频免费看| 中国一级特黄高清免费的大片中国一级黄色片 | 性xxxx视频播放免费| 黄色一级视频免费| 亚洲黄色在线观看网站| 国产一级淫片免费播放| 男男黄GAY片免费网站WWW| 亚洲国产精品嫩草影院在线观看| 24小时日本在线www免费的| selaoban在线视频免费精品| 亚洲另类自拍丝袜第1页| 免费精品国产自产拍在| 亚洲欧洲日韩国产| 国内精品乱码卡1卡2卡3免费| 日本一区二区三区免费高清在线| 2048亚洲精品国产| 日韩精品成人无码专区免费| h视频在线免费观看| 亚洲一区在线视频观看| 狠狠色伊人亚洲综合成人| 成人免费视频试看120秒| 国产精品免费高清在线观看| 久久久久亚洲Av片无码v| 岛国大片免费在线观看| 久久成人a毛片免费观看网站| 亚洲AV无码一区二区三区电影| 亚洲av日韩av激情亚洲| 亚洲国产综合精品一区在线播放| 日本XXX黄区免费看| 97超高清在线观看免费视频| 亚洲国产综合精品| 亚洲国产精品嫩草影院在线观看 | 国产偷v国产偷v亚洲高清| 精品久久久久久久免费加勒比| 一级成人a做片免费|