Java中的Map集合如何根据key值排序?

Java中的Map集合如何根据key值排序(HashMap<String,Object>)?

Map集合的键(key)默认是按照它们的hashCode排序的,这在有时间不符合业务排序。如果你想要根据Map的key值进行排序,一般以下有几种方法可以实现。

方法一:使用TreeMap

使用TreeMap类,它会自动根据key的自然顺序或自定义比较器进行排序。

1、使用key(String)的自然排序:

代码示例:

// 假设Map为HashMap
Map<String, Integer> unsortedMap = new HashMap<>();  
// 添加元素到unsortedMap  
unsortedMap = ... ;  // 使用TreeMap进行排序
Map<String, Integer> sortedMap = new TreeMap<>(unsortedMap);

2、使用自定义规则排序,传入Comparator自定义排序规则:

// 假设为HashMap<String, Object> map
// 未排序的HashMap
Map<String, Object> unSortMap = ...; // 使用TreeMap并提供一个Comparator用于排序key
Map<String, Object> sortedMap = new TreeMap<>(new Comparator<String>() {@Overridepublic int compare(String k1, String k2) {// 对于字符串key升序排序return k1.compareTo(k2);// 若需要降序排序,则可以改为// return k2.compareTo(k1);}
});// 将原始Map的内容复制到TreeMap中,此时Map会根据key排序
sortedMap.putAll(unSortMap );

方法二:使用lambda表达式和Stream流简化操作

示例代码:

// 按照key 升序排序
Map<String, Object> sortedMap = unSortMap.entrySet().stream().sorted(Map.Entry.comparingByKey()).collect(Collectors.toMap(Map.Entry::getKey,Map.Entry::getValue,// 解决可能存在的键冲突问题,默认保留第一个值(oldValue, newValue) -> oldValue,// 提供一个新的TreeMap实例作为收集器,用于保持排序() -> new TreeMap<>() ));// 或者,如果要降序排序
Map<String, Object> sortedMapDescending = originalMap.entrySet().stream().sorted(Map.Entry.<String, Object>comparingByKey().reversed()).collect(Collectors.toMap(Map.Entry::getKey,Map.Entry::getValue,// 处理键冲突(oldValue, newValue) -> oldValue, () -> new TreeMap<>()));

注意:此处不论方法一、方法二,对于Map中key为String类型的数据,都是底层都是按照字典顺序进行排序的。

所以一旦有一些特殊要求的排序:

例如:key为:“123-234”,“2134-1234”,“2-123”,

        需要根据key排序为: “2-123”,“123-234”,“2134-1234”时,就需要重新书写自定义的排序方法 或者 考虑其他的方式实现指定key排序了。

讨论一下: 上面key值的Map该如何排序:

// 例:“2-123”,“123-234”,“2134-1234”Map<String, Object> unSortMap = new HashMap();
map.put("123-234","2");
map.put("2-123","1");
map.put("2134-1234","3");// 使得unSortMap 按照key值为“2-123”,“123-234”,“2134-1234”进行排序

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/742635.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

python自动爬取,保存并运行程序。

本文使用创作助手。 第一步&#xff08;可跳过&#xff0c;熟悉一下而已&#xff09;&#xff1a; 要在Python中新建一个文本文档并写入内容&#xff0c;可以使用文件操作功能。以下是一个示例代码&#xff1a; # 新建文本文档并写入内容 with open(output.txt, w, encoding…

STM32 | STM32F407ZE中断、按键、灯(续第三天)

上节回顾 STM32 | 库函数与寄存器开发区别及LED等和按键源码(第三天)一、 中断 中断概念 中断是指计算机运行过程中,出现某些意外情况需主机干预时,机器能自动停止正在运行的程序并转入处理新情况的程序,处理完毕后又返回原被暂停的程序继续运行(面试题)。 STM32外部中断…

2024年3月11日-3月17日(全面进行)

根据月计划&#xff0c;为了要考虑把产品代码吃透。先对于计算几何&#xff0c;图像处理&#xff0c;测量学基础&#xff0c;slam进行 当然&#xff0c;也要把ue继续进行着。ue的rpg和底层渲染。收集下虚幻商城的免费资源&#xff0c;万一以后做独立游戏用得到。其他的可以暂时…

智慧城市大模型来啦!港大百度推出UrbanGPT

论文作者解读链接&#xff1a;https://blog.csdn.net/qq_42715656/article/details/136681839 项目链接&#xff1a;https://urban-gpt.github.io/ 代码链接&#xff1a;https://github.com/HKUDS/UrbanGPT 论文链接&#xff1a;https://arxiv.org/abs/2403.00813 研究实验室链…

编曲制作软件Fruity Loops Studio 21 中文版及新如何选择适合FL Studio 版本

如果你有着满腔的音乐才华&#xff0c;想要自己在家里发片吗&#xff1f;还是听 MOBY 的电子舞曲不过瘾&#xff0c;要再帮他做做 REMIX&#xff1f;有朋友会说&#xff0c;我不懂乐理&#xff0c;不懂五线谱&#xff0c;怎么制作音乐&#xff1f;这话说得很好&#xff0c;说到…

力扣-[700. 二叉搜索树中的搜索]

递归法 确定递归函数的参数和返回值 递归函数的参数传入的就是根节点和要搜索的数值&#xff0c;返回的就是以这个搜索数值所在的节点。 代码如下&#xff1a; public TreeNode searchBST(TreeNode root, int val) 确定终止条件 如果root为空&#xff0c;返回null&#xff0c…

Apache Paimon系列之:认识Paimon

Apache Paimon系列之&#xff1a;认识Paimon 一、认识Paimon二、统一存储三、基本概念1.文件布局2.Snapshot3.清单文件4.数据文件5.分区6.一致性保证 一、认识Paimon Apache Paimon的架构&#xff1a; 如上架构所示&#xff1a; 读/写&#xff1a;Paimon 支持多种读/写数据和…

C++高级面试题:解释 C++ 中的函数对象适配器

解释 C 中的函数对象适配器 函数对象适配器是 C 中的一种编程技术&#xff0c;用于修改或增强现有的函数对象的行为。它们通常通过组合或包装现有的函数对象来实现所需的功能。 函数对象适配器允许我们在不修改原始函数对象的情况下&#xff0c;对其进行修改或扩展。这样可以…

4、设计模式之建造者模式(Builder)

一、什么是建造者模式 建造者模式是一种创建型设计模式&#xff0c;也叫生成器模式。 定义&#xff1a;封装一个复杂对象构造过程&#xff0c;并允许按步骤构造。 解释&#xff1a;就是将复杂对象的创建过程拆分成多个简单对象的创建过程&#xff0c;并将这些简单对象组合起来…

使用 ReclaiMe Pro 进行 RAIDZ 数据恢复

天津鸿萌科贸发展有限公司是 ReclaiMe Pro 数据恢复软件授权代理商。 ZFS 是一个开源文件系统&#xff0c;主要用于 FreeNAS 和 NAS4Free 存储系统。在开发 ZFS 时&#xff0c;主要目标是可靠性&#xff0c;这是通过写时复制、冗余元数据、日志等不同功能来实现的。ZFS 使用自…

修改表结构

目录 修改表结构 创建数据表插入数据 修改已有列 修改 member 表的 name 列的定义 为表增加列 增加一个 address 列&#xff0c;这个列上不设置默认值 增加一个 sex 列&#xff0c;这个列上设置默认值 删除表中的列 删除 sex 列 Oracle从入门到总裁:​​​​​​https…

Kibana中的KQL语法

Kibana中的KQL语法 注意 KQL匹配时是不区分大小写的&#xff0c;可以使用括号改变匹配优先级&#xff1b;另外一个要点就是&#xff0c;匹配是包含&#xff0c;某个字段包含某个词&#xff0c;而不是某个字段的值等于某个词。 等值匹配&#xff08;equals&#xff09; 分词…

SpringSecurity两种验证方式及调用流程

一、HttpBasic方式 <security:http-basic/> 二、Formlogin方式 <security:form-login login-page"/userLogin" /> 三、SpringSecurity执行流程

华为机试题-字符串压缩

题目 给定段英文句子和—个英文单词列表。英文句子包含英文单词和标点符号,其中: 1)英文单词只包含[a-zA-Z]范国内的字符; 2)标点符号包括逗号、句号、双引号(双引号两边至少有一个空格)。 如果列表中有单词在句子中存在(大小写不敏感)且该单词未被双引号包含,则使 用该单词在列…

【LeetCode】升级打怪之路 Day 18:二叉树题型 —— 树的深度、高度、路经

今日题目&#xff1a; 104. 二叉树的最大深度111. 二叉树的最小深度110. 平衡二叉树257. 二叉树的所有路径112. 路径总和 目录 Problem 1&#xff1a;树的深度LC 104. 二叉树的最大深度 【easy】LC 111. 二叉树的最小深度 【易错】 Problem 2&#xff1a;树的高度LC 110. 平衡二…

【 TypeScript 】TypeScript的数据类型有哪些?

1. 是什么 ts和js 几乎一样&#xff0c;拥有相同的数据类型&#xff0c;另外在js基础上提供了更加实用的类型供开发使用 在开发阶段&#xff0c;可以为明确的变量定义某种类型&#xff0c;这样ts就能在编译阶段进行类型检查&#xff0c;当类型不符合预期结果的时候就会出现错误…

人类的三大非理性怪癖

人们对自己拥有的东西迷恋到不能自拔。 人们总是把注意力集中到白己会失去什么&#xff0c;而不是会得到什么。 人们经常假定别人看待交易的角度和自己一样。 所有权依恋 一个人总是对于自己拥有所有权的物件给予更高的评价。 所有权效应的特性 1.人们不仅对白己拥有所有…

工具推荐:有哪些工具可以搭建本地知识库?

大家是否心头藏着一个个的记录本&#xff0c;里面写满了工作日常、业务过程、个人想法等等&#xff0c;但是随着这个记录本日渐丰满&#xff0c;寻找特定信息的难度也在逐渐增大。如果有一个空间&#xff0c;既像你的记录本一样方便记录&#xff0c;又可以快速检索&#xff0c;…

19113133262(微信同号)2024年环境能源与全球市场营销国际学术会议(ICEEGM 2024)

2024年环境能源与全球市场营销国际学术会议&#xff08;ICEEGM 2024) 会议主题: (主题包括但不限于, 更多主题请咨询会务组苏老师) 节能技术 煤矿工程与技术 能源存储技术 可再生能源 热能与动力工程 能源工程与环境工程 可再生能源技术和系统 能源安全和清洁利用 矿…

1688平台最关键的接口接入实例|获得1688商品详情| 按关键字搜索商品| 按图搜索1688商品(拍立淘)| 获得淘口令真实url

参数说明 通用参数说明 version:API版本key:调用key,测试key:test_api_keyapi_name:API类型[item_get,item_search]cache:[yes,no]默认yes&#xff0c;将调用缓存的数据&#xff0c;速度比较快result_type:[json,xml,serialize,var_export]返回数据格式&#xff0c;默认为jsonl…