在 Java 中创建有序映射
映射是 Java 中存储键值对的数据结构。映射是存在于 Collection
层次结构中的 interface
。这些键是唯一的,因此不允许重复键;但是,映射到键的变量可以有重复的值。HashMap
、LinkedHashMap
和 TreeMap
等类实现了 Map
接口。
使用 Java 中的 TreeMap
类对映射进行排序
下面,该程序演示了 Java 程序中的映射排序。
import java.util.TreeMap;
public class Main {
public static void main(String[] args) {
TreeMap<String, Integer> map = new TreeMap<String, Integer>();
map.put("Third", 1);
map.put("First", 2);
map.put("Second", 3);
for (String key: map.keySet()) {
System.out.println(key + " ,ID = "+ map.get(key) );
}
}
}
TreeMap
类按升序对映射值进行排序。它还在内部实现了 SortedMap
接口,因此使用 new 关键字创建映射实例。
树图中的数据类型在实例化时指定。Map
键是 String
类型,它的值是 Integer
类型。
put
函数在树图中插入键值对。现在,定义了一个 for-each
循环来遍历映射。在 Java 中,无法直接迭代映射。因此,映射的键最初被转换为 Set
实例。
map.keySet
函数返回映射中存在的键的 Set
。此函数位于 TreeMap
类中,并返回当前键的有序视图。get
函数获取与键对应的值。
下面是按升序排列的输出。
First ,ID = 2
Second ,ID = 3
Third ,ID = 1
使用 Java 8 函数创建映射排序
Java 8 提供对函数式编程的支持,允许用户在函数链上工作。
Streams
是 java.util
包中的一个接口,它可以轻松地在单个语句中处理顺序操作。Streams
函数在发射器发射数据的管道中工作;它会根据用户的需求进行过滤、处理、转换等等。
package F09;
import java.util.LinkedHashMap;
import java.util.Map;
import java.util.stream.Collectors;
import java.util.stream.Stream;
import static java.util.AbstractMap.SimpleEntry;
public class MapOrdering {
public static void main(String[] args) {
Map<String, String> mapSortedByKey = Stream.of(
new SimpleEntry<>("key3", "value1"),
new SimpleEntry<>("key1", "value2"),
new SimpleEntry<>("key2", "value3"))
.sorted(Map.Entry.comparingByKey())
.collect(Collectors.toMap(Map.Entry::getKey,
Map.Entry::getValue,
(oldVal, newValue) -> oldVal,
LinkedHashMap::new));
System.out.println();
System.out.print("Ordered List: ");
for (String s1 : mapSortedByKey.keySet()) {
System.out.print(" " + s1);
}
}
}
Stream
接口提供各种函数,并在不同的类中实现它以处理它们。在这里,键值对流是使用 new SimpleEntry
类形成的。这些值被插入到 of
函数中以形成一个流。
在链系列中,sorted
函数被调用。该函数采用 Comparator
实例,根据定义的顺序按顺序排列键。函数 comparingByKey
返回按自然升序比较键的比较器。
sorted
函数最终返回按升序排列的值流。Stream
类的 collect
函数在新的 LinkedHashMap
实例中收集给定的映射值。该类保留所提供序列的插入顺序。该函数将 Collector
实例作为参数。
第一个参数是创建新容器的供应商 toMap
函数。第二个参数是累积值的 BiConsumer
,最后一个参数是充当合并结果的组合器的 BiConsumer
。因此,LinkedHashMap::new
命令组合结果并返回形成的实例。
mapSortedByKey
实例现在包含使用上面的 for-each
循环迭代的顺序映射元素。结果映射键打印在下面的标准输出中。
Ordered List: key1 key2 key3
相关文章
Java 中的选择排序算法
发布时间:2023/10/17 浏览次数:151 分类:Java
-
本教程演示了 Java 中的选择排序算法。选择排序是首先选择列表或数组中最小的元素并与第一个元素或数组交换的方法;然后,第二个缩小的元素与第二个元素交换。
在 Java 中使用 stream.orted() 对列表进行排序
发布时间:2023/10/17 浏览次数:54 分类:Java
-
本文介绍了如何在 Java 中使用 Stream sorted() 方法。这也演示了如何使用比较器对用户定义的列表进行流排序。本教程将详细介绍 Java 中的 Stream API 提供的 stream sorted() 方法。
Java 中拓扑排序的实现
发布时间:2023/10/17 浏览次数:87 分类:Java
-
我们将在 Java 中使用深度优先搜索技术在有向无环图上实现拓扑排序算法。这篇深入的文章将教你如何以递归顺序在有向无环图上实现拓扑排序。本教程分为两个部分。
Java 基数排序算法
发布时间:2023/10/17 浏览次数:200 分类:Java
-
本教程详细解释了基数排序算法并演示了 Java 中的实现。在基数排序算法中,元素的排序首先将具有相同位值的单个数字分组,然后按照升序或降序排序。本教程详细解释了基数排序算法,并演
如何在 Java 中连接两个列表
发布时间:2023/10/17 浏览次数:99 分类:Java
-
在 java 中可以使用不同的方法来连接两个列表,而不改变原来的列表,比如流、参数化构造函数、Predeclared List 和 addAll()方法。
如何在 Java 中创建一个新的列表
发布时间:2023/10/17 浏览次数:84 分类:Java
-
本文介绍了在 Java 中创建新列表的方法本教程将讨论了在 Java 中创建不同类型列表的方法。Java 中的列表 List 是一个接口,由 ArrayList、LinkedList、Vector 和 Stack 实现。
如何在 Java 中打印列表
发布时间:2023/10/17 浏览次数:73 分类:Java
-
它通过实例讨论了如何在 Java 中打印出列表的每一个元素。我们将介绍一些可以打印出 Java 中所有列表项的方法。在示例中,我们将使用模型类来演示如何创建模型对象列表,然后在其中打印元
在 Java 中初始化字符串列表
发布时间:2023/10/17 浏览次数:69 分类:Java
-
在本教程中,我们将看到在 Java 中初始化字符串列表的各种方法。由于列表是一个接口,我们不能直接将其实例化,我们可以使用 ArrayList,LinkedList 和 Vector 来实例化一个列表。
Java 中遍历列表
发布时间:2023/10/16 浏览次数:113 分类:Java
-
这篇文章将要遍历 Java 中列表的所有元素。本教程介绍了如何遍历 Java 中的列表,并列出了一些示例代码来理解该主题。列表是 Java 中的一个接口,具有多个实现类,例如 ArrayList,LinkedList 等。