先说遇到的问题吧,,,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;
}
}
}
总结: 其实写代码遇到问题很正常的,保持一个平和的心态去解决,一切都可以搞定的