• NameValueCollection 与 HashTable的区别


    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;

  • 相关阅读:
    css实现文字渐变
    js 模拟window.open 打开新窗口
    在centos上安装nodejs
    css多行省略
    Vue 中渲染字符串形式的组件标签
    vue 中结合百度地图获取当前城市
    vue-cli 项目实现路由懒加载
    JavaScript学习-2循环
    早期自学jQuery-一入门
    JavaScript学习-1
  • 原文地址:https://www.cnblogs.com/guanjie20/p/2216235.html
Copyright © 2020-2023  润新知