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

时间:2023-02-08 02:52:36



          先说遇到的问题吧,,,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;
}
}


}



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