在做项目的同时,遇到有一个对ArrayList进行排序的功能,在网上查找了些有关与这方面的代码,最后找到了如下的代码:

先定义一个类A:

public class A{    private int level;    public A(int level){        this.level = level;    }        public int getLevel()    {        return level;    }    public void setLevel(int level)    {        this.level = level;    }}

然后定义一个SortComparator类,实现Comparator接口:

import java.util.Comparator;public class SortComparator implements Comparator {@Overridepublic int compare(Object lhs, Object rhs) {A a = (A) lhs;A b = (A) rhs;return (b.getLevel() - a.getLevel());}}

最后在Activity中,实现排序的方法:

List<A> list = new ArrayList<A>();        list.add(new A(1));        list.add(new A(2));        list.add(new A(3));                Comparator comp = new SortComparator();        Collections.sort(list,comp);

就完成了对ArrayList按照level从达到小进行排序。

其实在网上很多的类似的例子上说,在实现Comparator接口的时候,它的返回值可以是0,其实在我测试的时候,它的返回值如果是0的话,达不到排序的效果。

更多相关文章

  1. 浅谈Java中Collections.sort对List排序的两种方法
  2. Python list sort方法的具体使用
  3. python list.sort()根据多个关键字排序的方法实现
  4. android EditText设置不可写
  5. Android(安卓)拨号器的简单实现
  6. android实现字体闪烁动画的方法
  7. Android中不同应用间实现SharedPreferences数据共享
  8. [Android(安卓)NDK]Android(安卓)JNI开发例子 ---3 在JNI中实现o
  9. android 拨打紧急号码,通话时开启免提功能实现

随机推荐

  1. 细谈Mysql的存储过程和存储函数
  2. mysql 8.0.15 winx64解压版图文安装教程
  3. mysql 8.0.15 winx64压缩包安装配置方法
  4. 浅谈sql语句中GROUP BY 和 HAVING的使用
  5. 简单讲解sql语句中的group by的使用方法
  6. SQL语句中OR和AND的混合使用的小技巧
  7. 关于SQL语句中的AND和OR执行顺序遇到的问
  8. 从零开始学习SQL查询语句执行顺序
  9. 简单了解MySQL SELECT执行顺序
  10. MySQL如何快速的创建千万级测试数据