Map进行排序

package com.jt.test;

import java.util.*;

/**
 * @Author: ldj
 * @Date: 2022/02/16/11:39
 * @Description: 对map进行排序
 */
public class SplicingXml {

    public static void main(String[] args) {

        Map<String, String> dateMap = new HashMap<>();
        dateMap.put("1天", "day1");
        dateMap.put("5天", "day5");
        dateMap.put("4天", "day4");
        dateMap.put("2天", "day2");
        dateMap.put("3天", "day3");

        //------------------对key键值按字典升序排序---------------------
        Set<String> keySet = dateMap.keySet();
        List<String> list = new ArrayList<>(keySet);
        Collections.sort(list);

        for (int i = 0; i < list.size(); i++) {
            System.out.println(list.get(i) + " => " + dateMap.get(list.get(i)));
        }

        //------------------按插入顺序进行遍历("有序map")---------------------------
        Map<String, String> linkedHashMap = new LinkedHashMap();
        linkedHashMap.put("A", "a");
        linkedHashMap.put("B", "b");
        linkedHashMap.put("D", "d");
        linkedHashMap.put("F", "f");
        linkedHashMap.put("C", "c");

        //使用foreach遍历 (最简洁,性能要求不高,推荐)
        linkedHashMap.forEach((k, v) -> System.out.println(k + ":" + v));

        //使用迭代器遍历1  (效率高)
        Iterator<Map.Entry<String, String>> entries = linkedHashMap.entrySet().iterator();

        while (entries.hasNext()) {
            Map.Entry<String, String> entry = entries.next();
            String key = entry.getKey();
            String value = entry.getValue();
            System.out.println(key + ":" + value);
        }

        //使用迭代器遍历2 (效率低)
        Iterator<String> iterator = linkedHashMap.keySet().iterator();

        while (iterator.hasNext()) {
            String key = iterator.next();
            String value = linkedHashMap.get(key);
            System.out.println(key + ":" + value);
        }
    }
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在集合中使用Map进行排序是一种常见的操作。Map是一种键值对的数据结构,其中的键是唯一的,而值可以重复。当需要对Map进行排序时,通常是根据键或者值的特定规则进行比较和排序。 首先,可以将Map中的键或者值取出来,放入一个List集合中。然后,可以使用集合的排序方法进行排序。在排序过程中,可以根据具体需求选择是对键还是对值进行排序。比如,可以使用Collections.sort()方法对List进行排序。 如果要对键进行排序,可以使用Comparator接口来定义排序规则,然后将该规则传递给Collections.sort()方法。例如: ``` Map<Integer, String> map = new HashMap<>(); // 添加一些键值对 List<Integer> keys = new ArrayList<>(map.keySet()); Collections.sort(keys, new Comparator<Integer>() { @Override public int compare(Integer o1, Integer o2) { // 定义排序规则,返回负数表示o1小于o2,返回0表示相等,返回正数表示o1大于o2 return o1.compareTo(o2); } }); ``` 如果要对值进行排序,同样可以使用Comparator接口来定义排序规则。例如: ``` List<String> values = new ArrayList<>(map.values()); Collections.sort(values, new Comparator<String>() { @Override public int compare(String o1, String o2) { // 定义排序规则,返回负数表示o1小于o2,返回0表示相等,返回正数表示o1大于o2 return o1.compareTo(o2); } }); ``` 最后,可以根据排序后的List中的键或者值,再对原始的Map进行遍历,按照排序后的顺序进行操作。 综上所述,通过将Map中的键或值转移到List集合中,并使用集合的排序方法和Comparator接口定义排序规则,可以在集合中对Map进行排序
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值