10. Java 中的 HashSet 和 HashMap 有什么区别?

2024-08-27 23:20
文章标签 java 区别 hashset hashmap

本文主要是介绍10. Java 中的 HashSet 和 HashMap 有什么区别?,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

HashSetHashMap 是 Java 集合框架中的两个重要类,它们都基于哈希表(Hash Table)实现,并且在许多方面共享类似的特性。然而,它们的用途和实现上有一些重要的区别。

1. 功能和用途

  • HashSet:

    • HashSet 是一个实现了 Set 接口的集合类,用于存储唯一的元素。集合中的元素不能重复。

    • 它不保证集合的顺序(插入顺序也不保证),并且不允许存储 null 元素(在某些实现中允许一个 null 元素,但如果多次插入 null,也只会保留一个 null)。

    • 主要用于需要确保元素唯一性的场景。

  • HashMap:

    • HashMap 是一个实现了 Map 接口的集合类,用于存储键值对(key-value pair)。每个键是唯一的,但多个键可以映射到相同的值。

    • HashMap 不保证键值对的顺序,也允许一个 null 键和多个 null 值。

    • 主要用于需要通过键快速查找值的场景。

2. 内部实现

  • HashSet 的实现:

    • HashSet 实际上是基于 HashMap 实现的。每当一个元素被添加到 HashSet 中时,HashSet 将这个元素作为 HashMap 的键存储,而 HashMap 的值是一个常量 PRESENT(通常是一个静态的 Object)。

    private static final Object PRESENT = new Object();
    private transient HashMap<E,Object> map;
    ​
    public boolean add(E e) {return map.put(e, PRESENT) == null;
    }
  • HashMap 的实现:

    • HashMap 使用哈希表来存储键值对。键通过 hashCode() 方法计算哈希值,并且哈希冲突通过链表或红黑树处理(在 Java 8 及之后的版本中,链表长度超过一定阈值后会转换为红黑树)。

3. 主要方法

  • HashSet:

    • add(E e): 添加元素到集合中,如果元素已经存在,则不改变集合,返回 false

    • remove(Object o): 从集合中删除指定元素,返回是否成功删除。

    • contains(Object o): 检查集合中是否包含指定元素,返回 truefalse

    • size(): 返回集合中元素的数量。

  • HashMap:

    • put(K key, V value): 将键值对存储到 HashMap 中,如果键已经存在,则更新其对应的值,返回旧值。

    • get(Object key): 根据键查找并返回对应的值,如果键不存在则返回 null

    • remove(Object key): 删除指定键及其对应的值,返回被删除的值。

    • containsKey(Object key): 检查是否存在指定的键,返回 truefalse

    • containsValue(Object value): 检查是否存在指定的值,返回 truefalse

    • size(): 返回 HashMap 中键值对的数量。

4. 使用场景

  • HashSet 的典型使用场景:

    • 当需要存储一组唯一的元素时,如:去除列表中的重复值、检查某个元素是否存在于集合中等。

    HashSet<String> set = new HashSet<>();
    set.add("Apple");
    set.add("Banana");
    set.add("Apple"); // 该操作不会重复添加 "Apple"
  • HashMap 的典型使用场景:

    • 当需要通过键快速查找值时,如:实现字典、缓存等功能。

    HashMap<String, Integer> map = new HashMap<>();
    map.put("Apple", 1);
    map.put("Banana", 2);
    int count = map.get("Apple"); // 返回 1

5. 性能

  • 时间复杂度:

    • HashSetHashMap 的常见操作(如 addremovecontains)的平均时间复杂度都是 O(1),但在最坏情况下(哈希冲突严重)可能退化为 O(n)。

    • HashMap 的查找和插入操作由于涉及键值对,性能可能稍微复杂一些,但总体而言与 HashSet 类似。

  • 空间复杂度:

    • HashMap 由于存储了键值对,因此比 HashSet 占用更多的内存空间。

总结

  • HashSet 用于存储唯一的元素,内部使用 HashMap 实现,其主要关注的是元素的唯一性和快速查找。

  • HashMap 用于存储键值对,支持通过键快速访问值,并允许一个键对应一个值。

  • 选择 HashSet 还是 HashMap 主要取决于你的需求:如果只需要唯一的元素集合,选择 HashSet;如果需要通过键来映射和查找值,选择 HashMap

这篇关于10. Java 中的 HashSet 和 HashMap 有什么区别?的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1113077

相关文章

Java 实用工具类Spring 的 AnnotationUtils详解

《Java实用工具类Spring的AnnotationUtils详解》Spring框架提供了一个强大的注解工具类org.springframework.core.annotation.Annot... 目录前言一、AnnotationUtils 的常用方法二、常见应用场景三、与 JDK 原生注解 API 的

Java controller接口出入参时间序列化转换操作方法(两种)

《Javacontroller接口出入参时间序列化转换操作方法(两种)》:本文主要介绍Javacontroller接口出入参时间序列化转换操作方法,本文给大家列举两种简单方法,感兴趣的朋友一起看... 目录方式一、使用注解方式二、统一配置场景:在controller编写的接口,在前后端交互过程中一般都会涉及

Java中的StringBuilder之如何高效构建字符串

《Java中的StringBuilder之如何高效构建字符串》本文将深入浅出地介绍StringBuilder的使用方法、性能优势以及相关字符串处理技术,结合代码示例帮助读者更好地理解和应用,希望对大家... 目录关键点什么是 StringBuilder?为什么需要 StringBuilder?如何使用 St

使用Java将各种数据写入Excel表格的操作示例

《使用Java将各种数据写入Excel表格的操作示例》在数据处理与管理领域,Excel凭借其强大的功能和广泛的应用,成为了数据存储与展示的重要工具,在Java开发过程中,常常需要将不同类型的数据,本文... 目录前言安装免费Java库1. 写入文本、或数值到 Excel单元格2. 写入数组到 Excel表格

Java并发编程之如何优雅关闭钩子Shutdown Hook

《Java并发编程之如何优雅关闭钩子ShutdownHook》这篇文章主要为大家详细介绍了Java如何实现优雅关闭钩子ShutdownHook,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起... 目录关闭钩子简介关闭钩子应用场景数据库连接实战演示使用关闭钩子的注意事项开源框架中的关闭钩子机制1.

Maven中引入 springboot 相关依赖的方式(最新推荐)

《Maven中引入springboot相关依赖的方式(最新推荐)》:本文主要介绍Maven中引入springboot相关依赖的方式(最新推荐),本文给大家介绍的非常详细,对大家的学习或工作具有... 目录Maven中引入 springboot 相关依赖的方式1. 不使用版本管理(不推荐)2、使用版本管理(推

Java 中的 @SneakyThrows 注解使用方法(简化异常处理的利与弊)

《Java中的@SneakyThrows注解使用方法(简化异常处理的利与弊)》为了简化异常处理,Lombok提供了一个强大的注解@SneakyThrows,本文将详细介绍@SneakyThro... 目录1. @SneakyThrows 简介 1.1 什么是 Lombok?2. @SneakyThrows

在 Spring Boot 中实现异常处理最佳实践

《在SpringBoot中实现异常处理最佳实践》本文介绍如何在SpringBoot中实现异常处理,涵盖核心概念、实现方法、与先前查询的集成、性能分析、常见问题和最佳实践,感兴趣的朋友一起看看吧... 目录一、Spring Boot 异常处理的背景与核心概念1.1 为什么需要异常处理?1.2 Spring B

如何在 Spring Boot 中实现 FreeMarker 模板

《如何在SpringBoot中实现FreeMarker模板》FreeMarker是一种功能强大、轻量级的模板引擎,用于在Java应用中生成动态文本输出(如HTML、XML、邮件内容等),本文... 目录什么是 FreeMarker 模板?在 Spring Boot 中实现 FreeMarker 模板1. 环

SpringMVC 通过ajax 前后端数据交互的实现方法

《SpringMVC通过ajax前后端数据交互的实现方法》:本文主要介绍SpringMVC通过ajax前后端数据交互的实现方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价... 在前端的开发过程中,经常在html页面通过AJAX进行前后端数据的交互,SpringMVC的controll