当前位置: 首页 > news >正文

C#面试常考随笔11:Dictionary<K, V>、Hashtable的内部实现原理是什么?效率如何?

Dictionary<K, V>

  • 底层数据结构:使用哈希表(Hash Table),由一个数组和链表(或在.NET Core 2.1 及之后版本中,当链表长度达到一定阈值时转换为红黑树)组成。数组中的每个元素称为一个桶(Bucket),用于存储键值对。
  • 工作原理:添加键值对时,先计算键(Key)的哈希码,通过哈希码对数组长度取模,得到对应的桶索引。若该桶为空,直接将键值对存入;若不为空(即发生哈希冲突),则以链表(或红黑树)的形式将新的键值对添加到该桶的链表(或红黑树)中。查找元素时,先计算键的哈希码定位到桶,然后在桶内的链表(或红黑树)中通过键的比较(调用Equals方法)找到对应的值。

Hashtable

  • 底层数据结构:同样基于哈希表实现,由数组和链表构成。数组中的每个元素是一个桶,用于存储键值对。
  • 工作原理:添加键值对时,计算键的哈希码,对数组长度取模确定桶索引。若桶为空,直接存入键值对;若桶已有元素(哈希冲突),则将新键值对添加到该桶的链表中。查找元素时,先计算键的哈希码定位桶,再在桶内链表中通过键的比较(调用Equals方法)获取对应的值。与Dictionary<K, V>不同的是,Hashtable是线程安全的,因为其方法实现中添加了synchronized关键字(在多线程环境下可确保线程同步,但性能相对Dictionary<K, V>较低),并且Hashtable的键和值都是object类型,存储和获取时可能需要类型转换,存在装箱和拆箱操作。

查找效率

  • 理想情况:二者在理想情况下查找效率都较高。它们内部都基于哈希表结构,通过计算键的哈希码来定位存储位置。在没有哈希冲突(即不同键计算出的哈希码对应到哈希表中的不同位置)时,查找操作可以在接近常数时间(O (1))内完成,即能快速定位到目标键值对。
  • 存在哈希冲突时
    • Hashtable:当发生哈希冲突,同一桶中存在多个键值对(以链表形式存储)时,查找时需要在链表中顺序比较键。如果哈希冲突严重,链表较长,查找效率会降低,时间复杂度可能退化为 O (n),n 为链表长度。不过,由于其内部实现对哈希函数等进行了优化,在一般情况下能较好地分散哈希值,减少冲突。
    • Dictionary<K, V> :在.NET Core 2.1 之前,处理哈希冲突与Hashtable类似,通过链表存储冲突的键值对,冲突严重时查找效率受链表长度影响。在.NET Core 2.1 及之后版本中,当链表长度达到一定阈值(通常为 8 )时,会将链表转换为红黑树。红黑树是一种自平衡的二叉搜索树,查找操作的时间复杂度为 O (log n),相比于长链表的 O (n),在冲突较多时能提供更稳定和高效的查找性能。
http://www.lryc.cn/news/530750.html

相关文章:

  • Linux防火墙基础
  • Qt u盘自动升级软件
  • 【Conda 和 虚拟环境详细指南】
  • Python递归函数深度解析:从原理到实战
  • OpenGL学习笔记(五):Textures 纹理
  • 【TypeScript】基础:数据类型
  • Notepad++消除生成bak文件
  • Android NDK
  • 内部知识库助力组织智力激发与信息共享实现业绩增长
  • 通过F12收集的信息
  • 用Python替代OpenMV IDE显示openmv USB 图像
  • c语言:编译和链接(详解)
  • 数据结构【单链表操作大全详解】【c语言版】(只有输入输出为了方便用的c++)
  • leetcode27.删除有序数组中的重复项
  • [c语言日寄]越界访问:意外的死循环
  • 【c++11】包装器
  • 信息学奥赛一本通 1422:【例题1】活动安排
  • 数据库、数据仓库、数据湖有什么不同
  • llama.cpp LLM_CHAT_TEMPLATE_DEEPSEEK_3
  • 深度学习的应用场景及常用技术
  • 小程序项目-购物-首页与准备
  • 网件r7000刷回原厂固件合集测评
  • 微信登录模块封装
  • [STM32 - 野火] - - - 固件库学习笔记 - - -十三.高级定时器
  • 后台管理系统通用页面抽离=>高阶组件+配置文件+hooks
  • 8.原型模式(Prototype)
  • Python-基于PyQt5,pdf2docx,pathlib的PDF转Word工具(专业版)
  • 13 尺寸结构模块(size.rs)
  • STM32单片机学习记录(2.2)
  • CSS 样式化表格:从基础到高级技巧