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将DOCX文档解析为Markdown文档的代码实现

《使用Java将DOCX文档解析为Markdown文档的代码实现》在现代文档处理中,Markdown(MD)因其简洁的语法和良好的可读性,逐渐成为开发者、技术写作者和内容创作者的首选格式,然而,许多文... 目录引言1. 工具和库介绍2. 安装依赖库3. 使用Apache POI解析DOCX文档4. 将解析

Java字符串处理全解析(String、StringBuilder与StringBuffer)

《Java字符串处理全解析(String、StringBuilder与StringBuffer)》:本文主要介绍Java字符串处理全解析(String、StringBuilder与StringBu... 目录Java字符串处理全解析:String、StringBuilder与StringBuffer一、St

springboot整合阿里云百炼DeepSeek实现sse流式打印的操作方法

《springboot整合阿里云百炼DeepSeek实现sse流式打印的操作方法》:本文主要介绍springboot整合阿里云百炼DeepSeek实现sse流式打印,本文给大家介绍的非常详细,对大... 目录1.开通阿里云百炼,获取到key2.新建SpringBoot项目3.工具类4.启动类5.测试类6.测

Spring Boot循环依赖原理、解决方案与最佳实践(全解析)

《SpringBoot循环依赖原理、解决方案与最佳实践(全解析)》循环依赖指两个或多个Bean相互直接或间接引用,形成闭环依赖关系,:本文主要介绍SpringBoot循环依赖原理、解决方案与最... 目录一、循环依赖的本质与危害1.1 什么是循环依赖?1.2 核心危害二、Spring的三级缓存机制2.1 三

go 指针接收者和值接收者的区别小结

《go指针接收者和值接收者的区别小结》在Go语言中,值接收者和指针接收者是方法定义中的两种接收者类型,本文主要介绍了go指针接收者和值接收者的区别小结,文中通过示例代码介绍的非常详细,需要的朋友们下... 目录go 指针接收者和值接收者的区别易错点辨析go 指针接收者和值接收者的区别指针接收者和值接收者的

在Spring Boot中浅尝内存泄漏的实战记录

《在SpringBoot中浅尝内存泄漏的实战记录》本文给大家分享在SpringBoot中浅尝内存泄漏的实战记录,结合实例代码给大家介绍的非常详细,感兴趣的朋友一起看看吧... 目录使用静态集合持有对象引用,阻止GC回收关键点:可执行代码:验证:1,运行程序(启动时添加JVM参数限制堆大小):2,访问 htt

SpringBoot集成Milvus实现数据增删改查功能

《SpringBoot集成Milvus实现数据增删改查功能》milvus支持的语言比较多,支持python,Java,Go,node等开发语言,本文主要介绍如何使用Java语言,采用springboo... 目录1、Milvus基本概念2、添加maven依赖3、配置yml文件4、创建MilvusClient

浅析Java中如何优雅地处理null值

《浅析Java中如何优雅地处理null值》这篇文章主要为大家详细介绍了如何结合Lambda表达式和Optional,让Java更优雅地处理null值,感兴趣的小伙伴可以跟随小编一起学习一下... 目录场景 1:不为 null 则执行场景 2:不为 null 则返回,为 null 则返回特定值或抛出异常场景

售价599元起! 华为路由器X1/Pro发布 配置与区别一览

《售价599元起!华为路由器X1/Pro发布配置与区别一览》华为路由器X1/Pro发布,有朋友留言问华为路由X1和X1Pro怎么选择,关于这个问题,本期图文将对这二款路由器做了期参数对比,大家看... 华为路由 X1 系列已经正式发布并开启预售,将在 4 月 25 日 10:08 正式开售,两款产品分别为华

SpringMVC获取请求参数的方法

《SpringMVC获取请求参数的方法》:本文主要介绍SpringMVC获取请求参数的方法,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下... 目录1、通过ServletAPI获取2、通过控制器方法的形参获取请求参数3、@RequestParam4、@