用Collections.sort方法对list排序有两种方法

 第一种是list中的对象实现Comparable接口,如下:

  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. public class Test{
  24. public static void main(String[] args) {
  25. User user1 = new User();
  26. user1.setName("a");
  27. user1.setOrder(1);
  28. User user2 = new User();
  29. user2.setName("b");
  30. user2.setOrder(2);
  31. List<User> list = new ArrayList<User>();
  32. //此处add user2再add user1
  33. list.add(user2);
  34. list.add(user1);
  35. Collections.sort(list);
  36. for(User u : list){
  37. System.out.println(u.getName());
  38. }
  39. }
  40. }


输出结果如下
a
 b

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

  1. /**
  2. * 根据order对User排序
  3. */
  4. public class User { //此处无需实现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. 主类中这样写即可(HastSet——>List——>sort进行排序):
  21. public class Test {
  22. public static void main(String[] args) {
  23. User user1 = new User();
  24. user1.setName("a");
  25. user1.setPrice(11);
  26. User user2 = new User();
  27. user2.setName("b");
  28. user2.setPrice(2);
  29. Set<User> Hset = new HashSet<User>();
  30. Hset.add(user2);
  31. Hset.add(user1);
  32. List<User> list = new ArrayList<User>();
  33. list.addAll(Hset);
  34. Collections.sort(list,new Comparator<User>(){
  35. public int compare(User arg0, User arg1) {
  36. return arg0.getPrice().compareTo(arg1.getPrice());
  37. }
  38. });
  39. for(User u : list){
  40. System.out.println(u.getName());
  41. }
  42. }

输出结果如下:

a
b

 

默认为升序,将。return arg0.getOrder().compareTo(arg1.getOrder());    改为:
return arg1.getOrder().compareTo(arg0.getOrder());   
就成降序的了。

java List 排序 Collections.sort()的更多相关文章

  1. java List 排序 Collections.sort() 对 List 排序

    class User { String name; String age;  public User(String name,String age){  this.name=name;  this.a ...

  2. Java语言利用Collections.sort对Map,List排序

    1.main方法包含TreeMap排序1,TreeMap排序2,HashMap排序,List<Integer>排序,List<Bean>排序,List<Map>排序 ...

  3. python 中的sort 和java中的Collections.sort()函数的使用

    x=[1,2,3] x.sort()对的,x这个都变了 y=x.sort()错误 y=sorted(x)对的,x拍好序的一个副本 python中用匿名函数和自定义函数排序:(很奇怪的是比较函数返回的是 ...

  4. Java—集合框架 Collections.sort()、Comparable接口和Comparator接口

    Collentions工具类--java.util.Collections Collentions是Java集合框架中,用来操作集合对象的工具类,也是Java集合框架的成员,与List.Map和Set ...

  5. 对List数组进行排序 Collections.sort(param1,param2)

    @SuppressWarnings("unchecked") List<PageData> group_items_list = (List<PageData&g ...

  6. JAVA对list集合进行排序Collections.sort()

    对一个集合中的对象进行排序,根据对象的某个指标的大小进行升序或降序排序.代码如下: // 进行降序排列 Collections.sort(list, new Comparator<ResultT ...

  7. Java中使用Collections.sort()方法对数字和字符串泛型的LIst进行排序

    在List的排序中常用的是Collections.sort()方法,可以对String类型和Integer类型泛型的List集合进行排序. 首先演示sort()方法对Integer类型泛型的List排 ...

  8. 在Java中使用Collections.sort 依据多个字段排序

    一.如何使用Collections工具类进行排序 使用Collections工具类进行排序主要有两种方式: 1.对象实现Comparable接口,重写compareTo方法 /** * @author ...

  9. Java-小技巧-006 List 排序 Collections.sort()

    一.数组操作类:Arrays 最早开始使用,查看方法二分查找:public static int binarySearch(数据类型[] a, 数据类型 key) 前提是有序的 equals 先排序 ...

随机推荐

  1. UVa 11375 - Matches

    http://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem&p ...

  2. PowerMock 遇到的问题——2

    如果我们要测试的类继承另一个类,而且在构造方法中有super():那么怎么Mock那个super语句呢? 在PowerMock中有一个suppressConstructor方法,具体写法如下: Pow ...

  3. form v

    <form name="example_form" action="http://google.com" method="POST"& ...

  4. Linux-VLAN

    Why Vlan? VLAN是为解决以太网的广播问题和安全性而提出的一种协议,它在以太网帧的基础上增加了VLAN头,用VLAN ID把用户划分为更小的工作组,限制不同工作组间的用户二层互访,每个工作组 ...

  5. bzoj 3529 数表 莫比乌斯反演+树状数组

    题目大意: 有一张N×m的数表,其第i行第j列(1 < =i < =礼,1 < =j < =m)的数值为能同时整除i和j的所有自然数之和.给定a,计算数表中不大于a的数之和. ...

  6. hadoop 常见问题

    1.Eclipse 读取hdfs文件错误:  java.io.IO Exception : Could not obtain block: blk_194219614024901469_1100 fi ...

  7. POJ 2887 Big String (块状数组)

    题意:给一个字符串(<=1000000)和n个操作(<2000),每个操作可以在某个位置插入一个字符,或者查询该位置的字符.问查询结果. 思路:块状数组. 如果将原来的字符串都存在一起,每 ...

  8. 加载不同的nib文件

    只需要实现nibName方法即可 另外还需在vc控制器初始化的时候不指定对应的nib文件名 -(NSString *)nibName { if(UI_USER_INTERFACE_IDIOM() == ...

  9. python字符decode与encode的问题

    同事在工作中遇到一个字符编码的问题:问题是:从mysql数据库中读出来的varchar类型数据在python是unicode类型的. 但他却对这个unicode字符进行了decode,因为他以为读出来 ...

  10. 【LeetCode OJ】Gas Station

    Problem link: http://oj.leetcode.com/problems/gas-station/ We can solve this problem by following al ...