每个元素是一个存储在 DictionaryEntry 对象中的键/值对。键不能为空引用(Visual Basic 中为 Nothing),但值可以。
用作 Hashtable 中的键的对象必须实现或继承 Object.GetHashCode 和 Object.Equals 方法。如果键相等性只是引用相等性,这些方法的继承实现将满足需要。此外,如果该键存在于 Hashtable 中,那么当使用相同参数调用这些方法时,这些方法必须生成相同的结果。只要键对象用作 Hashtable 中的键,它们就必须是永远不变的。
当把某个元素添加到 Hashtable 时,将根据键的哈希代码将该元素放入存储桶中。该键的后续查找将使用键的哈希代码只在一个特定存储桶中搜索,这将大大减少为查找一个元素所需的键比较的次数。
Hashtable 的加载因子确定元素与存储桶的最大比率。加载因子越小,平均查找速度越快,但消耗的内存也增加。默认的加载因子 1.0 通常提供速度和大小之间的最佳平衡。当创建 Hashtable 时,也可以指定其他加载因子。
当向 Hashtable 添加元素时,Hashtable 的实际加载因子将增加。当实际加载因子达到此加载因子时,Hashtable 中存储桶的数目自动增加到大于当前 Hashtable 存储桶数两倍的最小质数。
Hashtable 中的每个键对象必须提供其自己的哈希函数,可通过调用 GetHash 访问该函数。但是,可将任何实现 IHashCodeProvider 的对象传递到 Hashtable 构造函数,而且该哈希函数用于该表中的所有对象。
1、
遍历
Hashtable
的键值对:
方案一:
结果如下:
-KEY- -VALUE-
Third: !
Second: World
First: Hello
方案二:
方案三:
2、
实现可排序的
Hashtable
:
原本以为需要自己实现,经讨论发现微软已有类似功能的类库
SortedList
。
SortedList 在内部维护
两个数组以将数组存储到列表中;即,一个数组用于键,另一个数组用于相关联的值。每个元素都是一个可作为
DictionaryEntry 对象进行访问的键/值对。键不能为空引用(Visual Basic 中为
Nothing),但值可以。
SortedList 的容量是列表可拥有的元素数。随着向
SortedList 中添加元素,容量通过重新分配按需自动增加。可通过调用
TrimToSize 或通过显式设置
Capacity 属性减少容量。
SortedList 的元素将按照特定的
IComparer 实现(在创建
SortedList 时指定)或按照键本身提供的
IComparable 实现并依据键来进行排序。不论在哪种情况下,
SortedList 都不允许重复键。
索引顺序基于排序顺序。当添加元素时,元素将按正确的排序顺序插入
SortedList,同时索引会相应地进行调整。若移除了元素,索引也会相应地进行调整。因此,当在
SortedList 中添加或移除元素时,特定键/值对的索引可能会更改。
由于要进行排序,所以在
SortedList 上操作比在
Hashtable 上操作要慢。但是,
SortedList 允许通过相关联键或通过索引对值进行。