Java 根据map集合的key对map集合字典排序

本文详细介绍了一种在Java中对Map集合中的键进行字典排序的方法,通过使用ArrayList和Collections.sort()方法结合自定义比较器,实现了Map键的有序排列。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

这是工具类中的代码 

package com.demo.utils;

import java.util.ArrayList;
import java.util.Collections;
import java.util.HashMap;
import java.util.Map;

public class SortUtils {

    /**
     * 给map集合中的key实现字典排序
     * @param map
     * @return
     */
    public Map<String , Object> MapKeySort(Map<String , Object> map){
        ArrayList list = new ArrayList();
        for (Map.Entry<String, Object> entry : map.entrySet()) {
            list.add(entry.getKey());
            //System.out.println("key= " + entry.getKey() + " and value= " + entry.getValue());
        }

        HashMap<String , Object> newMap = new HashMap<String , Object>();
        //运用Collections的sort()方法对其进行排序 sort()方法需要传 连个参数,一个是需要进行排序的Collection 另一个是一个Comparator
        Collections.sort(list, new SpellComparatorUtils());
        for (int i = 0; i < list.size(); i++) {
            newMap.put(list.get(i).toString() , map.get(list.get(i).toString()));
        }
        return newMap;
    }
}

这是比较类

package com.demo.utils;

import java.util.Comparator;

public class SpellComparatorUtils implements Comparator {
    public int compare(Object o1, Object o2) {
        try {
            // 取得比较对象的汉字编码,并将其转换成字符串
            String s1 = new String(o1.toString().getBytes("GB2312"), "ISO-8859-1");
            String s2 = new String(o2.toString().getBytes("GB2312"), "ISO-8859-1");
            // 运用String类的 compareTo()方法对两对象进行比较
            return s1.compareTo(s2);
        } catch (Exception e) {
            e.printStackTrace();
        }
        return 0;
    }
}

请自行更改package !!!

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值