浅谈c# 之 hashtable 与 dictionary的代码实例:
dictionaryb6842da76bed01162354d37c4f2d3464 () hashtable()
第一、存储的数据类型
hashtable不是泛型的,不是类型安全的;dictionary是泛型的,是类型安全的;
hashtable的键值都是object类型的,但是dictionary的键值的数据类型是可以指定的。
也就是说如果往hashtable里面存入object以外的数据类型,则在取出该数据时,需要对其进行显示的类型转换,才能够正常使用。而dictionary则没有这个问题。
从这方面讲的话,hashtable相当于dictionary02675a7c8d33e53ab4967a8ba2cffc99
hashtable ht = new hashtable();
dictionary<string, int> dic = new dictionary<string, int>();
ht.add("a", 1);
dic.add("a", 1);
//console.writeline(ht["a"]+1); //编译错误!object类型不能和int类型直接进行相加。
console.writeline((int)ht["a"] + 1);//编译通过,输出结果为:2
console.writeline(dic["a"] + 1); //编译通过,输出结果为:2
第二、读取数据的顺序与添加数据的顺序的一致性
dictionary和hashtable的读取数据的顺序和添加数据时的数据的顺序的一致性均不能够保证,或者可以说没有一致性。
dictionary在只添加不删除的时候能够保持读取数据的顺序和添加时候的顺序是一致的;
但是经过删除和添加操作之后,就不能够保证读取数据的顺序和添加时候的顺序一致了。
dictionary<int, int> dic = new dictionary<int, int>();
dic.add(0, 0);
dic.add(1, 1);
dic.add(2, 2);
console.writeline("仅仅经过添加元素处理之后:");
foreach (keyvaluepair<int, int> kvp in dic)
{
console.writeline("key:" + kvp.key + " value:" + kvp.value);
}
dic.remove(0);
dic.add(3, 3);
console.writeline("经过删除和添加元素处理之后:");
foreach (keyvaluepair<int, int> kvp in dic)
{
console.writeline("key:" + kvp.key + " value:" + kvp.value);
}
console.readkey();
对于dicitionary而言,如果从中删除一个元素,则之后新添加的元素会填补这个被删除元素的位置,因而致使添加数据的顺序与读取数据的顺序是不一致的。
对于hashtable而言,它的数据存储顺序是按一定的算法算出来的,所以绝大多数情况下,它的数据读取顺序和数据添加顺序是不一致的。
所以如果你需要保持数据添加时的顺序的时候,最好不要用dictionary和hashtable。
第三、当用一个不存在的key值到hashtable或者dictionary中取值时
对于hashtable而言,如果用一个不存在的key值进行取值的话,会返回一个null;
hashtable ht = new hashtable();
console.writeline(ht["b"]==null);
console.readkey();
对于dictionary而言,如果用一个不存在的key值进行取值的话,会引发“system.collections.generic.keynotfoundexception”类型的异常。
所以在从dictionary或者hashtable取值时,可以先判断key值是否存在(用containskey()方法进行判断),以防止出现预期以外的值或者异常。
第四、线程安全性
dictionary不是线程安全的,hashtable是线程安全的。
以上就是浅谈c# 之 hashtable 与 dictionary的代码实例的详细内容。