.NET Dictionary使用多少个哈希桶?

8

我知道这是一个实现细节,但我很好奇:.NET字典中使用的哈希桶数量是否有限制? 我认为它将会是 大约在 2 * numberOfElements 左右,但有人确定吗(或者有没有文档记录)?


1
你有没有尝试查看源代码? - Patrick Hofman
1
请查看HashHelpers类。 - Sergey Berezovskiy
1
源代码有以下两行:int size = HashHelpers.GetPrime(capacity); buckets = new int[size]; - Habib
你是在问它可以有多少个还是现在它有多少个? - D Stanley
@DStanley:这么说吧,如果我在字典中存储了n个元素,那么f_1(n)f_2(n)是多少,使得numberOfBuckets满足*f_1(n) <= numberOfBuckets <= f_2(n)*。 - Heinzi
显示剩余5条评论
1个回答

11

简而言之:它使用的大小等于比 [numberOfElements] 大的第一个质数。然而并非考虑所有质数:它在表格中使用大小限制,对于更大的尺寸它会通过困难的方式计算出质数。

如果你查看源代码,你可以在名为 HashHelpers 的类中找到以下表格: (我猜这意味着你需要 720 万个项目才开始计算质数)

public static readonly int[] primes = {
        3, 7, 11, 17, 23, 29, 37, 47, 59, 71, 89, 107, 131, 163, 197, 239, 293, 353, 431, 521, 631, 761, 919,
        1103, 1327, 1597, 1931, 2333, 2801, 3371, 4049, 4861, 5839, 7013, 8419, 10103, 12143, 14591,
        17519, 21023, 25229, 30293, 36353, 43627, 52361, 62851, 75431, 90523, 108631, 130363, 156437,
        187751, 225307, 270371, 324449, 389357, 467237, 560689, 672827, 807403, 968897, 1162687, 1395263,
        1674319, 2009191, 2411033, 2893249, 3471899, 4166287, 4999559, 5999471, 7199369};

3
实际上,很多质数都缺失了。2、5、13、19、31等等。看起来它只是使用足够远的质数,因为担心所有中间的质数并不值得。 - Kendall Frey
@KendallFrey 我想是这样的。质数有很多。存储所有这些将是疯狂的。容量是17还是19并不重要。但是,他们并没有以最有效的方式来处理它:http://referencesource.microsoft.com/#mscorlib/system/collections/hashtable.cs#e8668bf19da49963 - Dennis_E

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接