咦,List集合按照日期进行排序,这不是很简单吗,sql一句话就搞定了呀。是呀,sql可以很简单的搞定,但是,我遇到的这种情况是第三方接口返回的数据,没有按照日期排序,这个,和第三方协商有时候可能不是那么容易哈。所以呢,就只能自己这边想办法咯;项目中跟着经理学到了重要的一点:分析定位到问题产生的原因,看看是谁的问题,是我们边,还是第三方那边;如果是第三方那边的问题,那么不要把所有希望都寄托在第三方那边;自己这边先想解决办法,万一第三方那边不好协商或者其他原因的情况下,自己这边有备选方案,不至于那么被动。 嗯~o(* ̄▽ ̄*)o 很有道理的样子,自己这边做好充足的准备,兵来将挡,水来土掩~~
假设有这样一个集合List
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator; //要引入的包,不要导错咯哦
//返回数据按照出生日期降序排 (我比较懒,方法头就不写了~~)
final SimpleDateFormat sdf = new SimpleDateFormat("yyyy/MM/dd HH:mm:ss");
Collections.sort(stuList, new Comparator(){
@Override
public int compare(Student arg0, Student arg1) {
int mark = 1;
try {
Date date0 = sdf.parse(arg0.getAtime());
Date date1 = sdf.parse(arg1.getActPJtime());
if(date0.getTime() > date1.getTime()){
mark = -1;
}
if(arg0.getBirthTime().equals(arg1.getBirthTime())){
mark = 0;
}
} catch (ParseException e) {
logger.error("日期转换异常", e);
e.printStackTrace();
}
return mark;
} //compare
});
貌似是Conllections中就有这个方法,关键时刻居然忘了-_-!! 反正这样做 就可以了,想了解更多的可以去看API