了解 HashMap 类对于开发人员来说至关重要,无论是在实际应用程序还是面试中。在这篇文章中,我们将探讨如何在 HashMap 中插入、更新和管理键值对。这些知识也将为我们的下一篇文章奠定基础,我们将深入研究 HashSet 并了解这两个集合之间的关系。
HashMap 将数据存储为键值对,允许高效的查找、更新和删除。以下是一些重要特征:
让我们通过代码片段更详细地探讨这些行为。
put() 方法向映射添加键值对。但是,如果键已经存在,则旧值将被替换。
Mapmap = new HashMap(); // Insert two key-value pairs map.put(1, 2); map.put(2, 3);
解释:
在这里,我们插入两个条目:
现在,如果我们尝试使用相同的键插入新值会发生什么?
// Replacing an existing value map.put(2, 4); // Key 2 already exists, so the value is replaced.
键 2 和值 3 已经存在,但是当我们调用 put(2, 4) 时,新值 4 替换了 旧值。这是 HashMap 的默认行为。
在许多情况下,如果键已经存在,您可能不希望替换值——如果处理不仔细,这可能会导致数据丢失。在这种情况下,我们可以使用 putIfAbsent() 方法。
// Ensuring value isn't replaced if key exists map.putIfAbsent(2, 5);
putIfAbsent() 方法仅在指定键 地图中尚未存在 时插入值。由于键 2 已经与值 4 关联,因此此处的方法调用不起作用。
System.out.println(map); // Output: {1=2, 2=4}
输出显示键 2 保留值 4,因为 putIfAbsent() 没有覆盖现有值。
HashMap 类是 Java 中用于存储键值对的强大工具,但了解其重复键的行为至关重要。了解何时使用 put() 和 putIfAbsent() 可以帮助您避免数据丢失并编写高效的代码。 HashMap 的基本操作平均时间复杂度为 O(1),是许多性能关键型任务的首选。
请继续关注下一篇文章,我们将探讨 HashSet 以及它如何在内部使用 HashMap 确保唯一性!
Java 基础知识
Array面试要点
Java 内存基础
快乐编码!
免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。
Copyright© 2022 湘ICP备2022001581号-3