如何理解 ListT和 DictionaryK,V 的扩容机制 ?

咨询区

  • Royi Namir

为什么 List 是按照 2倍 扩容。

private void EnsureCapacity(int min)
{if (this._items.Length < min){int num = (this._items.Length == 0) ? 4 : (this._items.Length * 2);if (num < min){num = min;}this.Capacity = num;}
}

Dictionary<K,V> 是按 素数 扩容。

private void Resize()
{int prime = HashHelpers.GetPrime(this.count * 2);int[] numArray = new int[prime];for (int i = 0; i < numArray.Length; i++){numArray[i] = -1;}Entry<TKey, TValue>[] destinationArray = new Entry<TKey, TValue>[prime];Array.Copy(this.entries, 0, destinationArray, 0, this.count);for (int j = 0; j < this.count; j++){int index = destinationArray[j].hashCode % prime;destinationArray[j].next = numArray[index];numArray[index] = j;}this.buckets = numArray;this.entries = destinationArray;
}

为什么不都按照 2倍 来呢?这样还可以实现代码复用。

回答区

  • Gman

Dictionary 是启发式的,它需要保证 hashcode 必须准均匀的分布在各个桶中,.NET 的 Dictionary 采用的是素数来实现这个均衡,下面是计算桶索引的算法。

int num = this.comparer.GetHashCode(key) & 2147483647; // make hash code positive
// get the remainder from division - that's our bucket index
int num2 = this.buckets[num % ((int)this.buckets.Length)];

不过 Java 采用的和 .NET 中的 List 是一样的扩容机制。

resize(2 * table.length);

在翻倍之后,java 会重新计算 hashcode 值的。

static int hash(int h) {// This function ensures that hashCodes that differ only by// constant multiples at each bit position have a bounded// number of collisions (approximately 8 at default load factor).h ^= (h >>> 20) ^ (h >>> 12);return h ^ (h >>> 7) ^ (h >>> 4);
}
static int indexFor(int h, int length) {return h & (length-1);
}// from put() method
int hash = hash(key.hashCode()); // get modified hash
int i = indexFor(hash, table.length); // trim the hash to the bucket count

List 不是启发式的,所以没有这么烦恼,

点评区

其实说到底,Dictionary采用素数,本质目的就是减少桶挂链,减少hashcode冲突,如果挂链过长,那就达不到 Contains,Add,Get 等操作的 O(1) 时间复杂度,这也就失去了 Dictionary 原本的特性。

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

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

相关文章

Android stduio之Plugin with id ‘com.android.application‘ not found解决办法

1、错误 Plugin with id com.android.application not found 2、解决办法 打开项目的build.gradle&#xff0c;看是否有buildscript&#xff5b;&#xff5d;&#xff0c;如果没有&#xff0c;加上 buildscript {repositories {mavenCentral() // or jcenter()}dependenc…

专科学会计还是计算机应用技术好,专科毕业想要学习会计专业,我专科是学计算机应用,但是毕业后家里让我学会计这门专业,具体是该怎么办呢...

技校网专门为您推荐的类似问题答案问题1&#xff1a;福建自考会计学需要考哪些专业,我是计算机专科毕业的020204 会计 (独立本科段) -http://www.fjzk.com.cn/portal/html/193/20081202000018.html--------------------------------------------------------------------------…

Android Studio之package org.junit does not exist解决办法

1、问题 运行Android studio出现下面错误 D:\*******\ExampleUnitTest.java Error:(3, 17) error: package org.junit does not exist Error:(5, 24) error: package org.junit does not exist Error:(11, 6) error: cannot find symbol class Test Error:(13, 9) error: cann…

2. 堪比JMeter的.Net压测工具 - Crank 进阶篇 - 认识yml

1. 前言入门篇我们已经成功运行hello.benchmarks.yml并输出测试结果&#xff0c;本篇我们就hello.benchmarks.yml、以及运行的shell脚本详细解读下其中的含义2. 剖析hello.benchmarks.yml2.1. job在hello.benchmarks.yml中我们定义了一个新的job: server&#xff0c;并指定了仓…

计算机应用问题,计算机应用的现状与发展的问题

计算机应用的现状与发展的问题来源&#xff1a;职称阁时间&#xff1a;2018-07-27 11:59热度&#xff1a;这篇论文主要介绍的是计算机应用的现状与发展的问题的相关内容&#xff0c;本文作者就是通过对计算机的应用现状等内容做出详细的阐述与介绍&#xff0c;特推荐这篇优秀的…

GoLang学习笔记——data_type

Go语言里面&#xff0c;每个变量也都是有类别的&#xff0c;这种类别叫做数据类型(Data Type)。 Go的数据类型有两种&#xff1a;一种是语言内置的数据类型&#xff0c;另外一种是通过语言提供的自定义数据类型方法自己定义的自定义数据类型。 数值型(Number) 数值型有三种&…

(2)从实际项目谈起,基于MEF的插件框架之总体设计

文章版权由作者李晓晖和博客园共有&#xff0c;若转载请于明显处标明出处&#xff1a;http://www.cnblogs.com/naaoveGIS/。 1.MEF框架简介 MEF的全称是Managed Extensibility Framework&#xff08;MEF&#xff09;&#xff0c;其是.net4.0的组成部分&#xff0c;在3.5上也可以…

Object-C 类,对象,运行时,isa

今天记录一下它的底层运作。 1&#xff1a; 类Class&#xff1a; typedef struct objc_class * Class; 从Class的定义可以看出&#xff0c;它是一个 objc_class 结构类型的指针&#xff0c;objc_class又是什么呢&#xff1f; struct objc_class{struct objc…

Avalonia跨平台入门第四篇之Popup在uos下问题

上一篇简单玩耍了Popup,这不正当我洋洋自得的时候前线传来战报:你家伙做的效果在UOS下面有问题;然后直接发来一张捷报:明明在乌班图和优麒麟都没啥问题,单单就你这个UOS牛,结果发现个神奇的特效:开启神奇的特效,果然神奇:来看看最终实现的效果:最终简单的效果先这样吧;以后有时…

C++之用std::nothrow分配内存失败不抛异常

1、std::nothrow介绍 1&#xff09;.malloc分配时&#xff0c;如果内存耗尽分配不出来&#xff0c;会直接返回NULL&#xff1b; 2.&#xff09;早期C版本&#xff0c;new分配时&#xff0c;如果内存耗尽分配不出来&#xff0c;也会直接返回NULL&#xff1b; 我们可以使用关键…

linux 安装apache http server

参考http://blog.csdn.net/sundenskyqq/article/details/24733923 但这篇博文有些东西有错。 参考http://www.cnblogs.com/zhuque/archive/2012/11/03/2763352.html 部分内容 步骤&#xff1a; 1、 下载apr、apr-util、pcre、Apache httpserver 地址如下&#xff1a; apr/ apr…

理科都要学大学计算机吗,女生不适合学理科专业?报考这些理科专业,一毕业就会遭到疯抢!...

男学理&#xff0c;女学文&#xff0c;似乎一直以来都是考生们报考专业时所“遵循”的一个主流&#xff0c;因为无论是专业学习知识理论的侧重点&#xff0c;还是未来就业的偏向性&#xff0c;文理科专业都呈现出非常大的差异。女生们或许更适合文科类专业的学习和就业&#xf…

8个使用JavaScript展示图片解决方案

1. JonDesign’s SmoothGallery 2.0 SmoothGallery demo 2. (E)2 Photo Gallery (E)2 Photo Gallery demo 3. jQuery Gallery 4. MooPix 5. Highslide JS Highslide JS demo 6. Flickrshow 7. Galleria Galleria demo 1 - Galleria demo 2 8. LightWindow v2.0

Linux中常用的操作指令(随时更新)

注&#xff1a;本文的所有内容都来源于网络&#xff0c;是本人再使用过程中遇到的一些不太常用、经常忘记的指令&#xff0c;出处太分散&#xff0c;无法标注。如有问题&#xff0c;请在下方留言&#xff0c;本人会及时更正或删除。谢谢&#xff01; CentOS 防火墙放开端口 #su…

Android之程序反复回调一个类的解决办法

1、问题 看了别人的代码&#xff0c;然后修改了下代码&#xff0c;程序总是死循环调用这个类&#xff0c;但是日志又好像有限&#xff0c;分析不出来&#xff0c;不知道是哪个地方有检测机制&#xff0c;导致这个类不断的创建&#xff0c;看了一上午不知所措。 2、解决办法 找…

Avalonia跨平台入门第三篇之Popup

前面已经分享了二篇关于Avalonia入门的文章,今天接着去摸索关于Popup的知识点;你还别说一上来就遇到坑了(后台定义的Popup直接黑框):然而在WPF中没有出现这个Bug:最后只能默默的再前台进行定义了:来看看最终实现的效果:后台打开无非就是Open方法就行,最后先来预告下一篇的效果滑…

SGU 160.Magic Multiplying Machine

时间限制:0.5s 空间限制6M 题意&#xff1a; 给出n个&#xff08;1<n<10000&#xff09;1~m&#xff08;2<m<1000&#xff09;范围内的数&#xff0c;选择其中任意个数&#xff0c;使它们的 乘积 模m 最大&#xff0c;输出最大的分数&#xff0c;和选择的数的编号。…

Swift和Objective-C混编

Swift中调用Objective-C文件 1.新建Swift文件SwiftViewController.swift 2.因为工程为OC编写,第一次创建会提示需要创建"桥接文件" 3.此时的工程会有SwiftViewController.swift文件和HelloWorld-Bridging-Header.h桥接文件 4.检查桥接文件HelloWorld-Bridging-Header…

计算机网络病毒解读,【数据挖掘论文】计算机网络病毒防御数据挖掘技术应用(共3503字)...

摘要&#xff1a;网络病毒对网络系统的攻击会造成危害性&#xff0c;并对计算机的网络安全造成影响&#xff0c;使重要文件中毒&#xff0c;导致重要数据丢失。本文将结合数据挖掘技术的相关模式进行探讨&#xff0c;浅析数据挖掘技术对计算机网络病毒防御的实际应用。关键词&a…

Java的LockSupport.park()实现分析

LockSupport类是Java6(JSR166-JUC)引入的一个类&#xff0c;提供了基本的线程同步原语。LockSupport实际上是调用了Unsafe类里的函数&#xff0c;归结到Unsafe里&#xff0c;只有两个函数&#xff1a; park&#xff1a;阻塞当前线程(Block current thread),字面理解park&#x…