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;

posted on 2011-05-24 23:10  liuhh  阅读(4231)  评论(1编辑  收藏  举报