java中Map根据key排序,根据value排序

简介: HashMap根据key或value排序(stream流操作)

HashMap根据key或value排序(stream流操作)


代码如下:


Map<String, Integer> map = new HashMap<>();
map.put("b", 2);
map.put("a", 1);
// 根据key排序
map.entrySet().stream().sorted(Map.Entry.comparingByKey()).forEach(System.out::println);
// 根据value排序  
map.entrySet().stream().sorted(Map.Entry.comparingByValue()).forEach(System.out::println);

结果



注意:如果map没有定义变量接收(没有声明泛型),在使用value排序的时候需要加上泛型。


例如下面这个map是一个List使用stream流分组计数获得的,没有使用变量接收,直接在后面继续操作了,在sorted排序的时候就需要加上泛型

相关文章
|
3天前
|
消息中间件 Java Kafka
Java大文件排序(有手就能学会),kafka面试题2024
Java大文件排序(有手就能学会),kafka面试题2024
|
5天前
|
存储 算法 搜索推荐
【Java高阶数据结构】图补充-拓扑排序
【Java高阶数据结构】图补充-拓扑排序
7 1
|
5天前
|
存储 安全 Java
Java一分钟之-Map接口与HashMap详解
【5月更文挑战第10天】Java集合框架中的`Map`接口用于存储唯一键值对,而`HashMap`是其快速实现,基于哈希表支持高效查找、添加和删除。本文介绍了`Map`的核心方法,如`put`、`get`和`remove`,以及`HashMap`的特性:快速访问、无序和非线程安全。讨论了键的唯一性、`equals()`和`hashCode()`的正确实现以及线程安全问题。通过示例展示了基本操作和自定义键的使用,强调理解这些概念对编写健壮代码的重要性。
10 0
|
5天前
|
存储 Java
【JAVA基础篇教学】第十篇:Java中Map详解说明
【JAVA基础篇教学】第十篇:Java中Map详解说明
|
5天前
|
存储 安全 Java
Java容器类List、ArrayList、Vector及map、HashTable、HashMap
Java容器类List、ArrayList、Vector及map、HashTable、HashMap
|
5天前
|
搜索推荐 Java Shell
8大Java排序方法(由简入繁),有代码详解和原理指导
8大Java排序方法(由简入繁),有代码详解和原理指导
33 0
|
5天前
|
Java
java Map删除值为null的元素
java Map删除值为null的元素
|
5天前
|
Java fastjson
Java将Map转换为实体类
Java将Map转换为实体类
|
5天前
|
监控 搜索推荐 算法
Java排序:原理、实现与应用
【4月更文挑战第28天】本文探讨了Java中的排序算法,包括原理和实现。Java利用Comparator接口进行元素比较,通过Arrays和Collections类的sort方法对数组和列表进行排序。示例展示了使用这些方法的基本代码。此外,还讨论了冒泡排序算法和自定义排序场景,以适应不同需求。理解这些排序机制有助于提升程序效率。
13 1
|
5天前
|
存储 安全 Java
[Java基础面试题] Map 接口相关
[Java基础面试题] Map 接口相关