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

相关文章

SpringBoot多环境配置数据读取方式

《SpringBoot多环境配置数据读取方式》SpringBoot通过环境隔离机制,支持properties/yaml/yml多格式配置,结合@Value、Environment和@Configura... 目录一、多环境配置的核心思路二、3种配置文件格式详解2.1 properties格式(传统格式)1.

Apache Ignite 与 Spring Boot 集成详细指南

《ApacheIgnite与SpringBoot集成详细指南》ApacheIgnite官方指南详解如何通过SpringBootStarter扩展实现自动配置,支持厚/轻客户端模式,简化Ign... 目录 一、背景:为什么需要这个集成? 二、两种集成方式(对应两种客户端模型) 三、方式一:自动配置 Thick

Spring WebClient从入门到精通

《SpringWebClient从入门到精通》本文详解SpringWebClient非阻塞响应式特性及优势,涵盖核心API、实战应用与性能优化,对比RestTemplate,为微服务通信提供高效解决... 目录一、WebClient 概述1.1 为什么选择 WebClient?1.2 WebClient 与

Java.lang.InterruptedException被中止异常的原因及解决方案

《Java.lang.InterruptedException被中止异常的原因及解决方案》Java.lang.InterruptedException是线程被中断时抛出的异常,用于协作停止执行,常见于... 目录报错问题报错原因解决方法Java.lang.InterruptedException 是 Jav

深入浅出SpringBoot WebSocket构建实时应用全面指南

《深入浅出SpringBootWebSocket构建实时应用全面指南》WebSocket是一种在单个TCP连接上进行全双工通信的协议,这篇文章主要为大家详细介绍了SpringBoot如何集成WebS... 目录前言为什么需要 WebSocketWebSocket 是什么Spring Boot 如何简化 We

java中pdf模版填充表单踩坑实战记录(itextPdf、openPdf、pdfbox)

《java中pdf模版填充表单踩坑实战记录(itextPdf、openPdf、pdfbox)》:本文主要介绍java中pdf模版填充表单踩坑的相关资料,OpenPDF、iText、PDFBox是三... 目录准备Pdf模版方法1:itextpdf7填充表单(1)加入依赖(2)代码(3)遇到的问题方法2:pd

Java Stream流之GroupBy的用法及应用场景

《JavaStream流之GroupBy的用法及应用场景》本教程将详细介绍如何在Java中使用Stream流的groupby方法,包括基本用法和一些常见的实际应用场景,感兴趣的朋友一起看看吧... 目录Java Stream流之GroupBy的用法1. 前言2. 基础概念什么是 GroupBy?Stream

SpringBoot监控API请求耗时的6中解决解决方案

《SpringBoot监控API请求耗时的6中解决解决方案》本文介绍SpringBoot中记录API请求耗时的6种方案,包括手动埋点、AOP切面、拦截器、Filter、事件监听、Micrometer+... 目录1. 简介2.实战案例2.1 手动记录2.2 自定义AOP记录2.3 拦截器技术2.4 使用Fi

最新Spring Security的基于内存用户认证方式

《最新SpringSecurity的基于内存用户认证方式》本文讲解SpringSecurity内存认证配置,适用于开发、测试等场景,通过代码创建用户及权限管理,支持密码加密,虽简单但不持久化,生产环... 目录1. 前言2. 因何选择内存认证?3. 基础配置实战❶ 创建Spring Security配置文件

Spring Security 单点登录与自动登录机制的实现原理

《SpringSecurity单点登录与自动登录机制的实现原理》本文探讨SpringSecurity实现单点登录(SSO)与自动登录机制,涵盖JWT跨系统认证、RememberMe持久化Token... 目录一、核心概念解析1.1 单点登录(SSO)1.2 自动登录(Remember Me)二、代码分析三、