java 中散列表(Hash Table)和散列集(Hash Set)是基于哈希算法实现的两种不同的数据结构

在 Java 中,散列表(Hash Table)和散列集(Hash Set)是两种不同的数据结构,但它们都基于哈希表的原理来实现。下面是它们的联系与区别、实现类以及各自的优缺点,并用表格进行对比整理。

联系与区别

联系
  • 基于哈希表原理:两者都使用哈希表来存储数据,通过哈希函数将键映射到数组中的特定位置。
  • 高效操作:都提供了快速的插入、删除和查找操作,时间复杂度平均为 O(1)。
区别
  • 数据结构类型
    • 散列表(Hash Table):存储键值对(key-value pairs),每个键映射到一个值。
    • 散列集(Hash Set):存储唯一的元素(values),不存储键值对。
  • 用途
    • 散列表(Hash Table):适用于需要存储和快速查找键值对的场景。
    • 散列集(Hash Set):适用于需要存储唯一元素且不需要键值对的场景。

实现类

散列表(Hash Table)
  • 主要实现类
    • HashMap:非线程安全,允许存储 null 值和 null 键。
    • Hashtable:线程安全,不允许存储 null 值和 null 键。
    • ConcurrentHashMap:线程安全,允许存储 null 值和 null 键,使用分段锁提高并发性能。
散列集(Hash Set)
  • 主要实现类
    • HashSet:基于 HashMap 实现,非线程安全,允许存储 null 值。
    • LinkedHashSet:基于 HashMap 和双向链表实现,非线程安全,允许存储 null 值,保证元素的插入顺序。
    • CopyOnWriteArraySet:线程安全,基于 CopyOnWriteArrayList 实现,不允许存储 null 值。

优缺点

散列表(Hash Table)
  • HashMap

    • 优点
      • 非线程安全,性能较高。
      • 允许存储 null 值和 null 键。
      • 支持链表和红黑树,提高查找效率。
    • 缺点
      • 非线程安全,需要外部同步。
      • 不保证元素的顺序。
  • Hashtable

    • 优点
      • 线程安全,所有公共方法都是同步的。
      • 不允许存储 null 值和 null 键。
    • 缺点
      • 性能较低,因为所有方法都是同步的。
      • 不允许存储 null 值和 null 键。
  • ConcurrentHashMap

    • 优点
      • 线程安全,使用分段锁提高并发性能。
      • 允许存储 null 值和 null 键。
      • 支持链表和红黑树,提高查找效率。
    • 缺点
      • 相比 HashMap,实现较为复杂。
散列集(Hash Set)
  • HashSet

    • 优点
      • 非线程安全,性能较高。
      • 允许存储 null 值。
      • 实现简单。
    • 缺点
      • 非线程安全,需要外部同步。
      • 不保证元素的顺序。
  • LinkedHashSet

    • 优点
      • 非线程安全,允许存储 null 值。
      • 保证元素的插入顺序。
    • 缺点
      • 相比 HashSet,插入和删除操作稍慢。
      • 非线程安全。
  • CopyOnWriteArraySet

    • 优点
      • 线程安全,适用于读多写少的场景。
      • 不允许存储 null 值。
    • 缺点
      • 写操作性能较低,因为每次写操作都会创建一个新的数组副本。
      • 不允许存储 null 值。

对比表格

特性HashMapHashtableConcurrentHashMapHashSetLinkedHashSetCopyOnWriteArraySet
实现基础基于 HashMap基于 Hashtable基于 ConcurrentHashMap基于 HashMap基于 HashMap 和双向链表基于 CopyOnWriteArrayList
存储重复元素不允许不允许不允许不允许不允许不允许
存储 null允许不允许允许允许允许不允许
存储 null允许不允许允许---
线程安全非线程安全线程安全线程安全非线程安全非线程安全线程安全
元素顺序不保证元素的顺序不保证元素的顺序不保证元素的顺序不保证元素的顺序保证元素的插入顺序不保证元素的顺序
内部结构数组 + 链表(或红黑树)数组 + 链表数组 + 链表(或红黑树) + 分段锁数组 + 链表(或红黑树)数组 + 链表(或红黑树) + 双向链表数组 + 链表(或红黑树)
性能一般情况下性能较高性能较低性能较高,但实现复杂一般情况下性能较高相比 HashSet,插入和删除操作稍慢写操作性能较低,读操作性能较高
适用场景不需要线程安全且不需要保证顺序的场景需要线程安全且不允许 null 值的场景需要线程安全且性能较高的场景不需要线程安全且不需要保证顺序的场景需要保证元素插入顺序的场景读多写少且需要线程安全的场景

通过以上对比,可以根据具体需求选择合适的散列表和散列集实现方式。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/73715.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

vue2自定义指令实现 el-input 输入数字,小数点两位 最高10位,不满足则截取符合规则的值作为新值

步骤 1:创建自定义指令 // 处理输入值,确保符合规则 function processValue(value) {// 过滤非数字和小数点let filtered value.replace(/[^\d.]/g, );const firstDotIndex filtered.indexOf(.);// 处理多个小数点,保留第一个if (firstDot…

10、基于osg引擎生成热力图高度图实现3D热力图可视化、3D热力图实时更新(带过渡效果)

1、结果 2、完整C代码 #include <sstream> #include <iomanip> #include <iostream> #include <vector> #include <random> #include <cmath> #include <functional> #include <osgViewer/viewer> #include <osgDB/Read…

海量数据查询加速:Presto、Trino、Apache Arrow

1. 引言 在大数据分析场景下,查询速度往往是影响业务决策效率的关键因素。随着数据量的增长,传统的行存储数据库难以满足低延迟的查询需求,因此,基于列式存储、向量化计算等技术的查询引擎应运而生。本篇文章将深入探讨 Presto、Trino、Apache Arrow 三种主流的查询优化工…

Pycharm 社区版安装教程

找到安装包双击安装文件---点击下一步 一般路径是&#xff1a;C:\Rambo\Software\Development 选择完成后就是如下地址&#xff1a; C:\Rambo\Software\Development\PyCharm Community Edition 2024.3.3 点击上述3个位置就可以了----下一步 等待安装就可以了---完成后点击完成…

vue3 elementUi table自由渲染组件

文章目录 前言CustomTable如何使用tableColumn 属性h函数创建原生元素创建组件动态生成 前言 elementui中的table组件&#xff0c;表格中想要自由地渲染内容&#xff0c;是一种比较麻烦的事情&#xff0c;比如你表格中想要某一列插入一个button按钮&#xff0c;是不是要用插槽…

Mermaid 子图 + 拖拽缩放:让流程图支持无限细节展示

在技术文档、项目管理和可视化分析中&#xff0c;流程图是传递复杂逻辑的核心工具。传统流程图往往静态且难以适应细节展示&#xff0c;而 Mermaid 与 svg-pan-zoom 的结合&#xff0c;则为这一痛点提供了完美解决方案。本文将深入解析如何通过 Mermaid 的子图&#xff08;subg…

前端权限系统

前端权限系统是为了确保用户只能访问他们有权限查看的资源而设计的。在现代前端开发中&#xff0c;权限控制不仅仅是简单的显示或隐藏元素&#xff0c;还涉及到对路由、组件、数据和操作权限的细致控制。下面是前端权限系统的常见设计方案和实现步骤。 前端权限系统的组成部分 …

Nature | TabPFN:表格基础模型用于小规模数据分析

表格数据是按行和列组织的电子表格形式&#xff0c;在从生物医学、粒子物理到经济学和气候科学等各个科学领域中无处不在 。基于表格其余列来填充标签列缺失值的基本预测任务&#xff0c;对于生物医学风险模型、药物研发和材料科学等各种应用至关重要。尽管深度学习彻底改变了从…

c++学习系列----003.写文件

c 写文件 文章目录 c 写文件1️⃣ 使用 ofstream 写入文本文件2️⃣ 追加模式写入3️⃣ 写入二进制文件4️⃣ 使用 fstream 进行读写5️⃣ 使用 fprintf()&#xff08;C 方式&#xff09;6️⃣ 使用 write() 低级 I/O 方式推荐方式 C 写文件的几种方式主要有以下几种&#xff1…

C语言及内核开发中的回调机制与设计模式分析

在C语言以及操作系统内核开发中,回调机制是一种至关重要的编程模式。它通过注册框架和定义回调函数,实现了模块间的解耦和灵活交互,为系统的扩展性和可维护性提供了有力支持。本文将深入探讨这种机制的工作原理、应用场景以及与设计模式的关联。 一、回调机制的核心概念 (…

浅谈StarRocks SQL性能检查与调优

StarRocks性能受数据建模、查询设计及资源配置核心影响。分桶键选择直接决定数据分布与Shuffle效率&#xff0c;物化视图可预计算复杂逻辑。执行计划需关注分区裁剪、谓词下推及Join策略&#xff0c;避免全表扫描或数据倾斜。资源层面&#xff0c;需平衡并行度、内存限制与网络…

stable Diffusion 中的 VAE是什么

在Stable Diffusion中&#xff0c;VAE&#xff08;Variational Autoencoder&#xff0c;变分自编码器&#xff09;是一个关键组件&#xff0c;用于生成高质量的图像。它通过将输入图像编码到潜在空间&#xff08;latent space&#xff09;&#xff0c;并在该空间中进行操作&…

从零开始 | C语言基础刷题DAY3

❤个人主页&#xff1a;折枝寄北的博客 目录 1.打印3的倍数的数2.从大到小输出3. 打印素数4.打印闰年5.最大公约数 1.打印3的倍数的数 题目&#xff1a; 写一个代码打印1-100之间所有3的倍数的数字 代码&#xff1a; int main(){int i 0;for (i 1; i < 100; i){if (i % …

告别死锁!Hyperlane:Rust 异步 Web 框架的终极解决方案

告别死锁&#xff01;Hyperlane&#xff1a;Rust异步Web框架的终极解决方案 &#x1f525; 为什么选择Hyperlane&#xff1f; Hyperlane是专为Rust开发者打造的高性能异步Web框架&#xff0c;通过革命性的并发控制设计&#xff0c;让您彻底摆脱多线程编程中的死锁噩梦。框架内…

CLR中的类型转换

CLR中的类型转换 字符串类型转换容器类型转换自定义类型相互转换项目设置CLR(Common Language Runtime,公共语言运行时)是微软.NET框架的核心组件,是微软对 CLI 标准的具体实现,负责管理和执行托管代码,提供跨语言互操作性、内存管理、安全性等关键服务CLR的类型转换机制…

QT5.15.2加载pdf为QGraphicsScene的背景

5.15.2使用pdf 必须要安装QT源码&#xff0c;可以看到编译器lib目录已经有pdf相关的lib文件&#xff0c;d是debug 1.找到源码目录&#xff1a;D:\soft\QT\5.15.2\Src\qtwebengine\include 复制这两个文件夹到编译器的包含目录中:D:\soft\QT\5.15.2\msvc2019_64\include 2.找…

MCP 开放协议

本文翻译整理自&#xff1a; https://modelcontextprotocol.io/introduction 文章目录 简介一、关于 MCP二、为什么选择MCP&#xff1f;通用架构 三、开始使用1、快速入门2、示例 四、教程五、探索 MCP六、贡献和支持反馈贡献支持和反馈 服务器开发者一、构建服务器1、我们将要…

主流区块链

文章目录 主流链1. Solana特点&#xff1a;适用场景&#xff1a;工具链&#xff1a; 2. Binance Smart Chain (BSC)特点&#xff1a;适用场景&#xff1a;工具链&#xff1a; 3. Avalanche特点&#xff1a;适用场景&#xff1a;工具链&#xff1a; 4. Polkadot特点&#xff1a;…

GaussDB备份数据常用命令

1、常用备份命令gs_dump 说明&#xff1a;是一个服务器端工具&#xff0c;可以在线导出数据库的数据&#xff0c;这些数据包含整个数据库或数据库中指定的对象&#xff08;如&#xff1a;模式&#xff0c;表&#xff0c;视图等&#xff09;&#xff0c;并且支持导出完整一致的数…

ctfshow-萌新赛刷题笔记

1. 给她 启动靶机&#xff0c;发现是sql注入&#xff0c;尝试后发现被转义\&#xff0c;思路到这里就断了&#xff0c;再看题目给她&#xff0c;想到git.有可能是.git文件泄露&#xff0c;dirsearch扫描一下果然是&#xff0c;用GitHack看一下git备份文件&#xff0c;得到hint…