1.NameValueCollection 和 HashTable的定义
散列表( Hash table,也叫哈希表),是根据关键码值(Key value)而直接进行访问的数据结构。也就是说,它通过把关键码值映射到表中一个位置来访问记录,以加快查找的速度。这个映射函数叫做散列函数,存放记录的数组叫做散列表。HashTable 表的优点:HashTable是System.Collections命名空间提供的一个容器,HashTable中的key/value均为object类型,所以HashTable可以支持任何类型的key/value键/值对。优点就在于其索引的方式,速度非常快。
NameValueCollection类集合是基于 NameObjectCollectionBase 类。但与 NameObjectCollectionBase 不同,该类在一个键下存储多个字符串值(就是键相同,值就连接起来如下例子)。该类可用于标头、查询字符串和窗体数据。每个元素都是一个键/值对。NameValueCollection 的容量是 NameValueCollection 可以保存的元素数。
NameValueCollection 的默认初始容量为零。随着向 NameValueCollection 中添加元素,容量通过重新分配按需自动增加。
如下例子:
NameValueCollection myCol = new NameValueCollection();
myCol.Add("red", "rojo");//如果键值red相同结果合并 rojo,rouge
myCol.Add("green", "verde");
myCol.Add("blue", "azul");
myCol.Add("red", "rouge");
2.NameValueCollection与Hashtable的区别
1. 首先前者不是以键值对存放,故这种类型的变量可以同时存放多个Name,当存放多个Name时,该Name的值不变,但是他的Value将会被追加到前一 个Value值得后面同时以逗号隔开,而同一个Hashtable里面绝对允许出现两个相同的键值,遵循数据结构中的哈希表。
2. 在存取方面,在NameValueCollection中,可用GetKey(i)获取指定索引的Name,Get(i)获取指定的索 引出值,而Hashtable将每个键值对存放到DictionaryEntry中,故在取值操作的时候需要用DictionaryEntry。
3. 在输出顺序上,前者是按存放顺序输出,而后者的顺旬不是。下面是如何对他们进行简单操作:
a.引用区别
hashtable:using System.Collections;
NameValueCollection:using System.Collections.Specialized;
b.键是否重复
NameValueCollection:允许重复.
HashTable是键-值集合,但键不能出现重复.
Hashtable ht = new Hashtable();
ht.Add("key","value");
ht.Add("key", "value1"); //出错
ht["key"] = "value1"; //正确
c.初始化的区别
初始化NameValueCollection需引用using System.Collections.Specialized;