HashSet、HashTable、Dictionary

 

a)         Hashset

HashSet、HashTable、Dictionary_第1张图片

b)         Hashtable

 

HashSet、HashTable、Dictionary_第2张图片

c)         Hashtable是非同步的,key不允许为空,value没有限制

 

HashSet、HashTable、Dictionary_第3张图片

d)         Dictionary与Hashtable

                         i.              比较

  1. Dictionary 类与 Hashtable 类的功能相同。对于值类型,特定类型(不包括 Object)的 Dictionary 的性能优于 Hashtable,这是因为 Hashtable 的元素属于 Object 类型,所以在存储或检索值类型时通常发生装箱和取消装箱操作。

                       ii.              使用选择

[1] 单线程程序中推荐使用 Dictionary, 有泛型优势, 且读取速度较快, 容量利用更充分.
[2] 多线程程序中推荐使用 Hashtable, 默认的 Hashtable 允许单线程写入, 多线程读取, 对 Hashtable 进一步调用 Synchronized() 方法可以获得完全线程安全的类型. 而 Dictionary 非线程安全, 必须人为使用 lock 语句进行保护, 效率大减.
[3] Dictionary 有按插入顺序排列数据的特性 (注: 但当调用 Remove() 删除过节点后顺序被打乱), 因此在需要体现顺序的情境中使用 Dictionary 能获得一定方便.

                      iii.              总而言之,尽量选择使用dictionary


 

你可能感兴趣的:(Hashtable)