Collections.sort Comparator排序

 

【转】java List 排序 Collections.sort



java List 排序 Collections.sort


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

代码: Java代码

  1. /** 
  2. * 根据order对User排序 
  3. */   
  4. public class User implements Comparable<User>{    
  5.     private String name;    
  6.     private Integer order;    
  7.     public String getName() {    
  8.         return name;    
  9.      }    
  10.     public void setName(String name) {    
  11.         this.name = name;    
  12.      }    
  13.     public Integer getOrder() {    
  14.         return order;    
  15.      }    
  16.     public void setOrder(Integer order) {    
  17.         this.order = order;    
  18.      }    
  19.     public int compareTo(User arg0) {    
  20.         return this.getOrder().compareTo(arg0.getOrder());    
  21.      }    
  22. }    
  23.    
  24.    
  25.    
  26. public class Test{    
  27.     public static void main(String[] args) {    
  28.           User user1 = new User();    
  29.           user1.setName("a"); user1.setOrder(1);    
  30.           User user2 = new User(); user2.setName("b");    
  31.           user2.setOrder(2);    
  32.           List<User> list = new ArrayList<User>();    
  33.         //此处add user2再add user1    
  34.          list.add(user2); list.add(user1);    
  35.          Collections.sort(list);    
  36.         for(User u : list){    
  37.              System.out.println(u.getName());    
  38.          }    
  39.      }    
  40. }
复制代码

Java代码

  1. <span style="">/**  
  2. * 根据order对User排序  
  3. */   
  4. public class User implements Comparable<User>{   
  5.     private String name;   
  6.     private Integer order;   
  7.     public String getName() {   
  8.         return name;   
  9.     }   
  10.     public void setName(String name) {   
  11.         this.name = name;   
  12.     }   
  13.     public Integer getOrder() {   
  14.         return order;   
  15.     }   
  16.     public void setOrder(Integer order) {   
  17.         this.order = order;   
  18.     }   
  19.     public int compareTo(User arg0) {   
  20.         return this.getOrder().compareTo(arg0.getOrder());   
  21.     }   
  22. }   
  23.    
  24. public class Test{   
  25.     public static void main(String[] args) {   
  26.          User user1 = new User();   
  27.          user1.setName("a"); user1.setOrder(1);    
  28.          User user2 = new User(); user2.setName("b");   
  29.          user2.setOrder(2);    
  30.          List<User> list = new ArrayList<User>();    
  31.         //此处add user2再add user1    
  32.         list.add(user2); list.add(user1);    
  33.         Collections.sort(list);    
  34.         for(User u : list){    
  35.             System.out.println(u.getName());    
  36.         }    
  37.     }    
  38. }   
  39.    
  40. </span>   
复制代码

输出结果如下 


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

代码: Java代码

  1. /** 
  2. * 根据order对User排序 */    
  3. public class User {    
  4. //此处无需实现Comparable接口    
  5.     private String name;    
  6.     private Integer order;    
  7.     public String getName() {    
  8.          return name;    
  9.      }    
  10.     public void setName(String name) {    
  11.         this.name = name;    
  12.      }    
  13.     public Integer getOrder() {    
  14.         return order;    
  15.      }    
  16.     public void setOrder(Integer order) {    
  17.        this.order = order;    
  18.      }    
  19. }    
  20.    
  21.    
  22.    
  23.    
  24. public class Test{    
  25.     public static void main(String[] args) {    
  26.         User user1 = new User();    
  27.         user1.setName("a");    
  28.         user1.setOrder(1);    
  29.         User user2 = new User();    
  30.         user2.setName("b");    
  31.         user2.setOrder(2);    
  32.         List<User> list = new ArrayList<User>();    
  33.         list.add(user2);    
  34.         list.add(user1);    
  35.         Collections.sort(list,new Comparator<User>(){    
  36.            public int compare(User arg0, User arg1) {    
  37.                return arg0.getOrder().compareTo(arg1.getOrder());    
  38.             }    
  39.         });    
  40.        for(User u : list){    
  41.            System.out.println(u.getName());    
  42.         }    
  43.      }    
  44. }   
复制代码

最简单的就是上面红色的字。。。。。。。。。。。 
默认为升序,将。return arg0.getOrder().compareTo(arg1.getOrder());    改为:

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

就成倒序的了。。

 

 

 


本文章为转载,在做对List排序的时候搜索的.
 

import java.util.Comparator;
import java.util.List;
import java.util.ArrayList;
import java.util.Collections;

class User {
 String name;
 String age;
 
 public User(String name,String age){
  this.name=name;
  this.age=age;
 }
 public String getAge() {
  return age;
 }
 public void setAge(String age) {
  this.age = age;
 }
 public String getName() {
  return name;
 }
 public void setName(String name) {
  this.name = name;
 } 
}

class ComparatorUser implements Comparator{

 public int compare(Object arg0, Object arg1) {
  User user0=(User)arg0;
  User user1=(User)arg1;
  //首先比较年龄,如果年龄相同,则比较名字

  int flag=user0.getAge().compareTo(user1.getAge());
  if(flag==0){
   return user0.getName().compareTo(user1.getName());
  }else{
   return flag;
  } 
 }
 
}

public class SortTest {

 
 public static void main(String[] args){
  List userlist=new ArrayList();
  userlist.add(new User("dd","4"));
  userlist.add(new User("aa","1"));
  userlist.add(new User("ee","5"));
  userlist.add(new User("bb","2")); 
  userlist.add(new User("ff","5"));
  userlist.add(new User("cc","3"));
  userlist.add(new User("gg","6"));
  
  ComparatorUser comparator=new ComparatorUser();
  Collections.sort(userlist, comparator);
   
  for (int i=0;i<userlist.size();i++){
   User user_temp=(User)userlist.get(i);
      System.out.println(user_temp.getAge()+","+user_temp.getName()); 
  }
  
 }
}

 //首先比较年龄,如果年龄相同,则比较名字


结果:
   1, aa
   2, bb
   3, cc
   4, dd
   5, ee
   5, ff
   6, gg

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值