Comparable,Comparator 接口

java.util.Collections.sort(List list)与Comparable,Comparator 接口
 
调用java.util.Collections.sort(List list)方法来进行排序的时候,
List内的Object都必须实现了Comparable接口。
否则出现下面的错误:
java.lang.ClassCastException
 at java.util.Arrays.mergeSort(Arrays.java:1152)
 at java.util.Arrays.sort(Arrays.java:1079)
 at java.util.Collections.sort(Collections.java:113)

 
或者调用
java.util.Collections.sort(List list,Comparator c),
可以临时声明一个Comparator 来实现排序。
 
Comparable接口的 public int compareTo(Object arg0) {]
返回值大于0,则this被排在后面。arg0放在前面。
可以参看Integer 的compareTo()方法:
 
    public int compareTo(Integer anotherInteger) {
 int thisVal = this.value;
 int anotherVal = anotherInteger.value;
 return (thisVal<anotherVal ? -1 : (thisVal==anotherVal ? 0 : 1));
    }
返回值>=0,则不调用Arrays.swap(Object x[], int a, int b) 方法。
 
copyright © lizongbo
通过java.util.Collections.sort(List list,Comparator c)里临时声明的Comparator
可以方便的实现顺序或者倒序排列。
copyright © lizongbo
示例如下:
copyright © lizongbo
  Collections.sort(imageList, new Comparator() {
    public int compare(Object a, Object b) {
      int orderA = Integer.parseInt( ( (Image) a).getSequence());
      int orderB = Integer.parseInt( ( (Image) b).getSequence());
      return orderA - orderB;
    }
  });
如果需要改变排列顺序
copyright © lizongbo
改成return orderb - orderA 即可。

具体可以参考学习例子有:
copyright © lizongbo
 
copyright © lizongbo
这是一个实现了点击表格标题栏来实现表格数据排序的例子。
 
copyright © lizongbo
ps:  Collection(包括ArrayList等)的remove(Object o)方法
(src:java.util.AbstractCollection.java)
if (o.equals(e.next())) {
      e.remove();
使用的equals来判断的,而如果没有重写equals方法的话,
实际调用Object的
public boolean equals(Object obj) {
 return (this == obj);
    }
 
因此,放进在集合里的元素,建议都重新实现自己的 equals方法。
 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值