JAVA list 排序

项目有个根据日期排序的难题。我已把查好的数据封装到了list中。日期存的是字符串类型。同事想出的办法。附上代码

import java.util.HashMap;
import java.util.Map;
import org.apache.commons.lang.StringUtils;
import java.util.Comparator


public class ComparatorArea implements Comparator {
Map<String, Integer> sortValue = new HashMap<String, Integer>();


public int compare(Object p1, Object p2) {
Object o1 = ((Map) p1).get("classDate").toString()+" "+((Map) p1).get("classtime").toString();
Object o2 = ((Map) p2).get("classDate").toString()+" "+((Map) p1).get("classtime").toString();
String key1 = o1 != null ? o1.toString() : "";
String key2 = o2 != null ? o2.toString() : "";
if (StringUtils.isEmpty(key1) && StringUtils.isEmpty(key2)) {
return 0;// 都为null或空串,相等
} else if (key1.equals(key2)) {
return 0;
} else if (StringUtils.isEmpty(key1) && !StringUtils.isEmpty(key2)) {
return 1;// null或空串越向后靠
} else if (!StringUtils.isEmpty(key1) && StringUtils.isEmpty(key2)) {
return -1;// null或空串越向后靠
} else if (key1.compareTo(key2) > 0) {
return -1;// null或空串越向后靠
} else if (key1.compareTo(key2) == 0) {
return 0;// null或空串越向后靠
} else if (key1.compareTo(key2) < 0) {
return 1;// null或空串越向后靠
} else {
return -1;
}
}
}
//用法
ComparatorArea comparator = new ComparatorArea();
Collections.sort(list,comparator);//这里存放已经封装好的要排序的list
System.out.println(list.toString());//之后直接对list进行输出即可

需要另外导入一个包。StringUtils是struts中的common-logging包
Java中,可以使用Collections类的sort方法对List进行排序。引用\[1\]中的代码展示了如何使用Collections.sort方法对一个包含整数的List进行排序。首先,创建一个ArrayList对象,并向其中添加整数元素。然后,使用Collections.sort方法对该List进行排序。最后,打印排序后的List。这种方法适用于简单的整数排序。 如果要对自定义对象进行排序,可以实现Comparable接口或使用Comparator接口。引用\[2\]中的代码展示了如何对一个包含自定义对象的List进行排序。首先,创建一个ArrayList对象,并向其中添加自定义对象。然后,使用Collections.sort方法对该List进行排序。最后,打印排序后的List。在这个例子中,自定义对象实现了Comparable接口,因此可以直接使用Collections.sort方法进行排序。 另一种方法是使用List的sort方法和Comparator接口。引用\[3\]中的代码展示了如何使用List的sort方法和Comparator接口对一个包含自定义对象的List进行排序。首先,创建一个ArrayList对象,并向其中添加自定义对象。然后,使用List的sort方法和Comparator.comparing方法对该List进行排序。最后,打印排序后的List。这种方法更简洁,只需要一行代码即可完成排序。 综上所述,可以根据需要选择合适的方法对Java中的List进行排序。 #### 引用[.reference_title] - *1* *3* [Java List排序的几种方式整理](https://blog.youkuaiyun.com/Wjhsmart/article/details/115935693)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [Java:详解List集合的排序功能](https://blog.youkuaiyun.com/weixin_43092673/article/details/123910945)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值