当前位置:首页 > 科技  > 软件

哈希表哪家强?几大编程语言吵起来了!

来源: 责编: 时间:2024-05-09 09:23:20 249观看
导读哈希表华山论剑话说这一日,编程语言联合国准备举办一次大会,主题为哈希表,给各大编程语言帝国都发去了邀请函。很快就到了大会这一天。联合国秘书长开场发言:“诸位,为促进技术交流与发展,增强各帝国友谊,联合委员会特设此盛

哈希表华山论剑

话说这一日,编程语言联合国准备举办一次大会,主题为哈希表,给各大编程语言帝国都发去了邀请函。BzS28资讯网——每日最新资讯28at.com

很快就到了大会这一天。BzS28资讯网——每日最新资讯28at.com

联合国秘书长开场发言:“诸位,为促进技术交流与发展,增强各帝国友谊,联合委员会特设此盛会,感谢诸位的捧场”BzS28资讯网——每日最新资讯28at.com

会场传来一阵鼓掌声······BzS28资讯网——每日最新资讯28at.com

秘书长继续发言:“本次大会的主题是哈希表,程序员们使用最多的数据容器之一,各大编程语言帝国相信都有实现。今天的大会就围绕哈希表分为几个议题讨论,首先是第一个议题:存储结构与冲突解决”BzS28资讯网——每日最新资讯28at.com

存储结构与冲突解决

来自GoLang帝国的map率先发言:“哈希表,哈希表,首先得是个表嘛,所以最基本的要用一个数组来存储,数组中的每一个元素叫做bucket。至于hash冲突嘛,就用链表来解决嘛”BzS28资讯网——每日最新资讯28at.com

图片图片BzS28资讯网——每日最新资讯28at.com

GoLang帝国的map说完,有人站了起来:“英雄所见略同!在下C++帝国的unordered_map,我们基本上也是选择的这种方法”BzS28资讯网——每日最新资讯28at.com

此时,Python帝国的代表提出了质疑:“链表确实可以解决冲突,不过嘛,这要是冲突太多,链表太长,搜寻起来岂不费时?”BzS28资讯网——每日最新资讯28at.com

GoLang帝国的map和C++帝国的unordered_map面面相觑,不知如何应对。BzS28资讯网——每日最新资讯28at.com

“链表太长的话,那就转成树结构!”,就在这时,又有人站了起来。BzS28资讯网——每日最新资讯28at.com

见有人起身,Python帝国代表转身问道:“在下乃Python帝国的字典dict,敢问阁下怎么称呼”BzS28资讯网——每日最新资讯28at.com

“我是Java帝国的HashMap,和前面两位兄台的策略大体相同,只是在冲突过多,具体来说链表长度超过8的时候就转换成红黑树的结构,以此加快查找”BzS28资讯网——每日最新资讯28at.com

图片图片BzS28资讯网——每日最新资讯28at.com

说完,map、unordered_map松了一口气,和HashMap一起坐下了。BzS28资讯网——每日最新资讯28at.com

dict继续发问:“在座的都是这个思路,用链表解决冲突?”BzS28资讯网——每日最新资讯28at.com

说完,另外一位代表站了起来,“等等,我们C#帝国的HashTable就没用链表!”BzS28资讯网——每日最新资讯28at.com

dict露出了满意的表情,“那你们是怎么解决冲突的呢?”BzS28资讯网——每日最新资讯28at.com

“咱HashTable内部使用的是双重散列法,咱内部不止一种哈希计算方式,一次Hash冲突,咱就换一个再算,直到找到有空位的地方存储”,HashTable回答到。BzS28资讯网——每日最新资讯28at.com

dict看起来有些失望,估计这也不是他所用的方式。BzS28资讯网——每日最新资讯28at.com

“你问了半天,还没说你们Python是怎么处理冲突的呢?”,Java帝国的HashMap开口了。BzS28资讯网——每日最新资讯28at.com

“是啊,是啊”,其他代表也跟着起哄。BzS28资讯网——每日最新资讯28at.com

见众人起哄,dict只好应答:“链表法固然不错,不过需要在插入数据过程中动态分配内存构建链表节点,开销不小,我们没有采用。”BzS28资讯网——每日最新资讯28at.com

“那到底用了啥,你倒是说啊,快急死我了”,C++的unordered_map有些急了。BzS28资讯网——每日最新资讯28at.com

“我们用的是一种叫开放寻址法的策略,如果发现了冲突,就按照制定的策略从这个位置往后找,直到找到有空的位置存储”,dict{}继续说到。BzS28资讯网——每日最新资讯28at.com

图片图片BzS28资讯网——每日最新资讯28at.com

“哪有那么简单的事,你把别人的位置占了,那对应那个位置的数据来了怎么办?还有查找怎么找?删除怎么处理?这不全乱套了吗”,unordered_map追问不舍。BzS28资讯网——每日最新资讯28at.com

“是这样的,按照我们既定的规则,在查找的时候就需要额外做一些工作,另外删除的时候也不能直接删除,否则会破坏规则链条·····”,接下来一段时间,dict给大家仔细介绍了他们的处理思路。BzS28资讯网——每日最新资讯28at.com

“你这个也太麻烦了,不如我们链表法来的清晰明了”BzS28资讯网——每日最新资讯28at.com

“这怎么就麻烦了?这好处不显而易见嘛?”,dict也不甘示弱。BzS28资讯网——每日最新资讯28at.com

这时,秘书长打断了大家的争辩:“诸位,诸位,静一静,静一静,咱们这个议题到此为止,进入下一个议题:哈希到位置映射”BzS28资讯网——每日最新资讯28at.com

哈希到位置映射

急性子的C++帝国代表unordered_map第一个说话:“这有什么好讨论的,不就是用hash值对哈希表数组长度进行一个求模运算吗?”BzS28资讯网——每日最新资讯28at.com

图片图片BzS28资讯网——每日最新资讯28at.com

“就是,这有什么好讨论的”,C#帝国的HashTable也附和到。BzS28资讯网——每日最新资讯28at.com

“哎,此言差矣,我就没用取模运算”,众人望去,这Python帝国的dict又要闹什么新鲜玩意。BzS28资讯网——每日最新资讯28at.com

GoLang帝国的map问道:“老哥用的什么办法,别卖关子了,快说来听听”BzS28资讯网——每日最新资讯28at.com

dict扫了众人一眼说到,“我的办法就是:”BzS28资讯网——每日最新资讯28at.com

图片图片BzS28资讯网——每日最新资讯28at.com

这是怎么个映射法?众代表皆摸不着头脑,议论纷纷,唯有Java帝国的HashMap听闻微微一笑。BzS28资讯网——每日最新资讯28at.com

dict见状问道:“HashMap兄台,莫非知晓其中玄机?”BzS28资讯网——每日最新资讯28at.com

只见HashMap不紧不慢的站了起来说到:“哈希表长度是2的幂次,减1之后的二进制均变成了1,比如长度16,减1变成15,也就是二进制1111。再进行与运算,相当于取了哈希值的低位,直接映射到对应的数组位置,与运算比取模运算要快不少。不瞒诸位,我HashMap中也是使用的这种方式,此乃雕虫小技,不值得炫耀”BzS28资讯网——每日最新资讯28at.com

图片图片BzS28资讯网——每日最新资讯28at.com

众代表听完纷纷点头称赞,dict不知何时却已坐下。BzS28资讯网——每日最新资讯28at.com

C#的HashTable问道:“这样直接取低几位,会不会造成Hash值到数组的映射不均匀,拿你举的例子来说,18的二进制是0001 0010,34的二进制是0010 0010,他们的低4位都一样,和1111与上以后都是0010,也就是都该存到数组的2号位,这岂不是一定程度上的增加了冲突的概率吗?”BzS28资讯网——每日最新资讯28at.com

突如其来的质疑并没有让HashMap慌乱,反而是从容不迫的解释到:“C#代表的这个问题提的非常好,不知dict兄台是如何处理的。我们的方案是在进行与运算映射之前,对hash值进行一个处理,具体来说就是将其高16位与低16位进行一个异或运算,如此一来,最终参与与运算的部分就融合了原始hash的全部信息,而不仅仅是低位。”BzS28资讯网——每日最新资讯28at.com

图片图片BzS28资讯网——每日最新资讯28at.com

众代表听完再次点头称赞。BzS28资讯网——每日最新资讯28at.com

秘书长打破了平静,“看来大家收获都颇丰,咱们接着下一个话题吧:初始容量与扩容”BzS28资讯网——每日最新资讯28at.com

初始容量与扩容

众代表这一次皆不争先,互相观望。BzS28资讯网——每日最新资讯28at.com

秘书长见状说到:“没人主动,那我可就要点名了······”BzS28资讯网——每日最新资讯28at.com

“那就我先吧”,Java帝国的HashMap站了起来,“我的默认初始容量是16,有一个叫负载因子的参数,默认是0.75。我的策略是,如果内部数组的空间使用了超过75%,那就要准备扩容了,否则后续Hash冲突的概率就会很大。哦对了,扩容时容量得是2的指数次方,原因前面已经交代了”BzS28资讯网——每日最新资讯28at.com

图片图片BzS28资讯网——每日最新资讯28at.com

dict第二个起身:“嗯,差不多,我的默认初始容量是8,扩容的时候也是要求是2的指数次方,另外我的负载因子是2/3,扩容时机比这位HashMap老哥更早一些”BzS28资讯网——每日最新资讯28at.com

C#帝国代表HashTable听闻也起身发言:“我的初始容量是3,至于负载因子嘛,我经过大量实验测试,得出的数据在两位之间,是0.72。容量大小方面我就没有2的指数次方的要求了,而是要求一个素数。之所以要求素数的原因,是因为我使用的求模运算进行的映射,使用素数的话,冲突会少一些。”BzS28资讯网——每日最新资讯28at.com

这时,C++帝国代表unordered_map也说话了,“巧了!我也是素数哎,你看,我提前把容量都算好存起来了,到时候扩容就挨个取就行了。”BzS28资讯网——每日最新资讯28at.com

图片图片BzS28资讯网——每日最新资讯28at.com

尾声

时间过的很快,在大家热情的讨论中,一上午时间很快就结束了。BzS28资讯网——每日最新资讯28at.com

大会临近尾声,秘书长致辞宣布:“感谢各位代表积极探讨,大会取得圆满成功,本次大会到此结束,咱们下次再会!”BzS28资讯网——每日最新资讯28at.com

会场再次传来一阵热烈的鼓掌声······BzS28资讯网——每日最新资讯28at.com

然而就在此时,会场外突然传来一个声音:“举办如此盛会,怎能少了我”BzS28资讯网——每日最新资讯28at.com

众人望去,皆叹:“他果然还是来了”BzS28资讯网——每日最新资讯28at.com

BzS28资讯网——每日最新资讯28at.com

本文链接:http://www.28at.com/showinfo-26-87483-0.html哈希表哪家强?几大编程语言吵起来了!

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: 事务钩子函数,打造高效支付系统

下一篇: Java 中的 HTTP 客户端库OkHttp、Apache HttpClient和HttpUrlConnection

标签:
  • 热门焦点
  • 官方承诺:K60至尊版将会首批升级MIUI 15

    全新的MIUI 15今天也有了消息,在官宣了K60至尊版将会搭载天玑9200+处理器和独显芯片X7的同时,Redmi给出了官方承诺,K60至尊重大更新首批升级,会首批推送MIUI 15。也就是说虽然
  • 8月总票房已突破10亿!《封神》第一:口碑已经成了

    8月5日消息,据灯塔专业版数据,截至8月5日9时35分,8月总票房(含预售)已突破10亿。其中,《封神》以大比分的优势领先。根据官方消息,目前该片总票房已经超过14.
  • 服务存储设计模式:Cache-Aside模式

    Cache-Aside模式一种常用的缓存方式,通常是把数据从主存储加载到KV缓存中,加速后续的访问。在存在重复度的场景,Cache-Aside可以提升服务性能,降低底层存储的压力,缺点是缓存和底
  • 量化指标是与非:挽救被量化指标扼杀的技术团队

    作者 | 刘新翠整理 | 徐杰承本文整理自快狗打车技术总监刘新翠在WOT2023大会上的主题分享,更多精彩内容及现场PPT,请关注51CTO技术栈公众号,发消息【WOT2023PPT】即可直接领取
  • 阿里大调整

    来源:产品刘有媒体报道称,近期淘宝天猫集团启动了近年来最大的人力制度改革,涉及员工绩效、层级体系等多个核心事项,目前已形成一个初步的“征求意见版”:1、取消P序列
  • iQOO 11S评测:行业唯一的200W标准版旗舰

    【Techweb评测】去年底,iQOO推出了“电竞旗舰”iQOO 11系列,作为一款性能强机,该机不仅全球首发2K 144Hz E6全感屏,搭载了第二代骁龙8平台及144Hz电竞
  • iQOO Neo8系列新品发布会

    旗舰双芯 更强更Pro
  • 英特尔Xe-HP项目终止,将专注Xe-HPC/HPG系列显卡

    据10 月 31 日消息报道,英特尔高级副总裁兼加速计算系统和图形事业部总经理 表示,Xe-HP“ Arctic Sound” 系列服务器 GPU 已经应用于 oneAPI devcloud 云服
  • 由于成本持续增加,笔记本产品价格预计将明显上涨

    根据知情人士透露,由于材料、物流等成本持续增加,笔记本产品价格预计将在2021年下半年有明显上涨。进入6月下旬以来,全球半导体芯片缺货情况加剧,显卡、处理器
Top