迹忆客 专注技术分享

当前位置:主页 > 学无止境 > 编程语言 > Java >

在 Java 中创建有序映射

作者:迹忆客 最近更新:2023/10/16 浏览次数:

映射是 Java 中存储键值对的数据结构。映射是存在于 Collection 层次结构中的 interface。这些键是唯一的,因此不允许重复键;但是,映射到键的变量可以有重复的值。HashMapLinkedHashMapTreeMap 等类实现了 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 提供对函数式编程的支持,允许用户在函数链上工作。

Streamsjava.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 中的选择排序算法

下一篇:没有了

转载请发邮件至 1244347461@qq.com 进行申请,经作者同意之后,转载请以链接形式注明出处

本文地址:

相关文章

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 等。

扫一扫阅读全部技术教程

社交账号
  • https://www.github.com/onmpw
  • qq:1244347461

最新推荐

教程更新

热门标签

扫码一下
查看教程更方便