zoukankan      html  css  js  c++  java
  • 在C#中应用哈希表(Hashtable)

    在C#中应用哈希表(Hashtable)
    一,哈希表(Hashtable)简述


    .NET Framework中,Hashtable是System.Collections命名空间提供的一个容器,用于处理和表现类似key/value的键值对,其中key通常可用来快速查找,同时key是区分大小写;value用于存储对应于key的值。Hashtable中key/value键值对均为object类型,所以Hashtable可以支持任何类型的key/value键值对.


    二,哈希表的简单操作


    在哈希表中添加一个key/value键值对:HashtableObject.Add(key,value);
    在哈希表中去除某个key/value键值对:HashtableObject.Remove(key);
    从哈希表中移除所有元素: HashtableObject.Clear();
    判断哈希表是否包含特定键key: HashtableObject.Contains(key);
    下面控制台程序将包含以上所有操作:
    using System;
    using System.Collections; //使用Hashtable时,必须引入这个命名空间
    class hashtable
    {
    public static void Main()
    {
    Hashtable ht=new Hashtable(); //创建一个Hashtable实例
    ht.Add("E","e");//添加key/value键值对
    ht.Add("A","a");
    ht.Add("C","c");
    ht.Add("B","b");
    string s=(string)ht["A"];
    if(ht.Contains("E")) //判断哈希表是否包含特定键,其返回值为true或false
    Console.WriteLine("the E key:exist");
    ht.Remove("C");//移除一个key/value键值对
    Console.WriteLine(ht["A"]);//此处输出a
    ht.Clear();//移除所有元素
    Console.WriteLine(ht["A"]); //此处将不会有任何输出
    }
    }


    三,遍历哈希表


    遍历哈希表需要用到DictionaryEntry Object,代码如下:
       //初始化类别下拉框
       IDictionaryEnumerator ide=sys.adTypeHS.GetEnumerator();

       for(int i=0;i<sys.adTypeHS.Count;i++){
        ide.MoveNext();
        if((short)ide.Key==ad.MyType)
        {
         adtype.SelectedIndex=i;
         break;
        }
        
       }


    四,对哈希表进行排序


    对哈希表进行排序在这里的定义是对key/value键值对中的key按一定规则重新排列,但是实际上这个定义是不能实现的,因为我们无法直接在Hashtable进行对key进行重新排列,如果需要Hashtable提供某种规则的输出,可以采用一种变通的做法:
    ArrayList akeys=new ArrayList(ht.Keys); //别忘了导入System.Collections
    akeys.Sort(); //按字母顺序进行排序
    for(string skey in akeys)
    {
    Console.Write(skey + ":");
    Console.WriteLine(ht[skey]);//排序后输出
    }



    hashtable用键/值对来......
    hashtable用键/值对来存储,它的每个条目实际上是DictionaryEntry类的实例,遍历的方法可以用:

    VB:
    Dim tempitem as DictionaryEntry
    For each tempitem in yourhashtable
    .......
    Next


    Dim tempitem as String  //这里我们认为它的键值为String
    For each tempitem in yourhashtable.Keys
    .......
    Next

    Dim tempitem as String  //如果值为String的话,如果为其它类型,你可以换其它类型益行了
    For each tempitem in yourhashtable.Values
    .......
    Next


    C#中没有For Each,它用的是foreach
    foreach (DictionaryEntry tempitem in yourhashtable) {...}
  • 相关阅读:
    Haskell Interactive Development in Emacs
    Access Java API in Groovy Script
    手工设置Eclipse文本编辑器的配色
    Color Theme of Emacs
    Gnucash的投资记录
    Special Forms and Syntax Sugars in Clojure
    Use w3m as Web Browser
    SSE指令集加速之 I420转BGR24
    【图像处理】 增加程序速度的方法
    TBB 入门笔记
  • 原文地址:https://www.cnblogs.com/flyfish/p/354292.html
Copyright © 2011-2022 走看看