ITPub博客

首页 > 应用开发 > Java > List排序用Collections.sort and Comparator

List排序用Collections.sort and Comparator

原创 Java 作者:zenzuguo 时间:2006-10-26 17:18:16 0 删除 编辑

/**
* example of list sort
* @param schedules
* @param schoolId
* @return boolean
*/
public boolean checkCourseTimes(List schedules, Long schoolId){
boolean flag=false;
Collections.sort(schedules, new Comparator() {
public int compare(Object a, Object b) {
Schedule cs1 = (Schedule) a;
Schedule cs2 = (Schedule) b;
Date cs1date=cs1.getStartTime();
Date cs2date=cs2.getStartTime();
int temp=cs1date.compareTo(cs2date);
return temp;
}
});
return flag;
}

另一个

/**
* 递归对tree进行sort
*
* @param channelCsTypes
*/
private void sort(List channelCsTypes, Comparator compara) {
if (channelCsTypes == null || channelCsTypes.size() < 1)
return;
for (int i = 0; i < channelCsTypes.size(); i++) {
List subs = ((ChannelCstype) channelCsTypes.get(i)).getSubTypes();
sort(subs, compara);
}
Collections.sort(channelCsTypes, compara);
}

public List loadAllCstypesByChannel(String channel) {
List result = new ArrayList();

//Todo orgernize the list

// sort the types
sort(result, new Comparator() {
public int compare(Object a, Object b) {
ChannelCstype cs1 = (ChannelCstype) a;
ChannelCstype cs2 = (ChannelCstype) b;
int s1 = cs1.getSort() != null ? cs1.getSort().intValue() : 0;
int s2 = cs2.getSort() != null ? cs2.getSort().intValue() : 0;
return s1 - s2;
}
});
return result;

}

[@more@]

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/106285/viewspace-873850/,如需转载,请注明出处,否则将追究法律责任。

下一篇: 日期操作相关
请登录后发表评论 登录
全部评论

注册时间:2012-12-30

  • 博文量
    84
  • 访问量
    829896