Java List排序

转载地址:点击打开链接


java List 排序 Collections.sort
用Collections.sort方法对list排序有两种方法
第一种是list中的对象实现Comparable接口,如下: 

    /**
    * 根据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());   
             }   
         }   
    }  

第二种方法是根据Collections.sort重载方法来实现,例如: 

    /**
    * 根据order对User排序 */   
    public class User {   
    //此处无需实现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());   
            }   
         }   
    }  

默认为升序,将。return arg0.getOrder().compareTo(arg1.getOrder());    改为:

return arg1.getOrder().compareTo(arg0.getOrder());   

就成倒序的了。。



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值