如何对 List<map>内对象进行排序

1 篇文章 0 订阅
1 篇文章 0 订阅

如何对 List内对象进行排序

**
使用sort()方法与reversed()进行倒叙排序

List<Map<String, String>> parse = (List<Map<String, String>>) JSONArray.parse(operateLog);
        parse.sort(Comparator.comparing((Map<String, String> map) -> (map.get("createTime"))).reversed());

如果<Map<String, Object>中的value是Object,需要进行强转

你可以使用Java的Collections工具类的sort方法来对List<Map<>>进行排序。首先,你需要实现一个Comparator接口,用于定义Map的比较规则。然后,使用Collections的sort方法,并传入你实现的Comparator对象作为参数,就可以对List<Map<>>进行排序了。 以下是一个示例代码,演示如何对List<Map<>>按照Map的某个键值进行排序: ```java import java.util.Collections; import java.util.Comparator; import java.util.List; import java.util.Map; public class MapSortExample { public static void main(String[] args) { List<Map<String, Integer>> list = getList(); // 假设你已经有一个List<Map<String, Integer>>对象 // 对List<Map<>>进行排序 Collections.sort(list, new Comparator<Map<String, Integer>>() { @Override public int compare(Map<String, Integer> map1, Map<String, Integer> map2) { // 这里假设你要按照Map的键 "key" 进行升序排序 Integer key1 = map1.get("key"); Integer key2 = map2.get("key"); return key1.compareTo(key2); } }); // 输出排序后的结果 for (Map<String, Integer> map : list) { System.out.println(map); } } // 获取一个示例的List<Map<>> private static List<Map<String, Integer>> getList() { // 这里只是一个示例,你可以根据实际需求构造自己的List<Map<>> List<Map<String, Integer>> list = new ArrayList<>(); Map<String, Integer> map1 = new HashMap<>(); map1.put("key", 3); map1.put("value", 100); list.add(map1); Map<String, Integer> map2 = new HashMap<>(); map2.put("key", 1); map2.put("value", 200); list.add(map2); Map<String, Integer> map3 = new HashMap<>(); map3.put("key", 2); map3.put("value", 300); list.add(map3); return list; } } ``` 上述代码,我们通过定义一个Comparator对象,以Map的键 "key" 进行升序排序。然后,使用Collections.sort方法对List<Map<>>进行排序,并输出排序后的结果。 希望能够帮助到你!如果有任何问题,请随时提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值