JAVA ArrayList利用Comparator实现自定义排序



          先说遇到的问题吧,,,ArrayList<String>  里面存放的本地文件路径,然后通过这个路径找到文件,按照文件的最后修改时间排序,,,,提起来没啥问题的,。,,当时写的代码这样的: 
         //根据路径对应的文件最后修改时间排序
private class SortByLastModifyTime implements Comparator {
@Override
public int compare(Object o1, Object o2) {
 try {
File file1 = new File((String)o1);
 File file2 = new File((String)o2);
 if (file1.lastModified() < file2.lastModified()){
 return 1;
 }else{
 return 0;
 }
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
return 0;
}
}
}
   //最后发现,怎么都不能实现排序,,,搞得人郁闷啊。,。,,奇怪怎么回事呢》?
    检查代码都没问题吧,,,但是我还是相信,肯定是我的原因, 没办法,找吧。。。。
   最后查看文档,发现返回值有正数,0,有负数。。。。那我上面为啥只写正数1,0呢》? 为啥没负数呢?
  原因找到了:

      int compare(Object o1, Object o2) 返回一个基本类型的整型
   如果要按照升序排序,
     则o1 小于o2,返回-1(负数),相等返回0,01大于02返回1(正数)
    如果要按照降序排序
     则o1 小于o2,返回1(正数),相等返回0,01大于02返回-1(负数)

   

   所以: 上面的问题就很明显了,

//根据路径对应的文件最后修改时间排序
private class SortByLastModifyTime implements Comparator {


@Override
public int compare(Object o1, Object o2) {
 try {
File file1 = new File((String)o1);
 File file2 = new File((String)o2);
 if (file1.lastModified() < file2.lastModified()){
 return 1;
 }else{
 return -1;
 }
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
return -1;
}
}


}



总结: 其实写代码遇到问题很正常的,保持一个平和的心态去解决,一切都可以搞定的






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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值