在C#中应用哈希表(Hashtable)

转载 2006年05月23日 23:30:00
在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,代码如下:
for(DictionaryEntry de in ht) //ht为一个Hashtable实例
{
Console.WriteLine(de.Key);//de.Key对应于key/value键值对key
Console.WriteLine(de.Value);//de.Key对应于key/value键值对value
}


四,对哈希表进行排序


对哈希表进行排序在这里的定义是对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]);//排序后输出
}

C#中哈希表(HashTable)的用法详解

1.  哈希表(HashTable)简述   在.NET Framework中,Hashtable是System.Collections命名空间提供的一个容器,用于处理和表现类似keyvalue...
  • killcwd
  • killcwd
  • 2016年01月04日 15:05
  • 458

C# Hashtable(哈希表)

C# 哈希表(Hashtable) Hashtable 类代表了一系列基于键的哈希代码组织起来的键/值对。它使用键来访问集合中的元素。 当您使用键访问元素时,则使用哈希表,而且您可以识...

c#中的Hashtable(哈希表、字典表)

概述及元素的添加官方文档 Hashtable优点 声明的格式、元素的添加 Hashtable元素的遍历Hashtable元素的删除Hashtable元素的查找 三种方法 Hashtable特...

C#中HashTable(哈希表)的用法

一,哈希表(Hashtable)简述   在.NET Framework中,Hashtable是System.Collections命名空间提供的一个容器,用于处理和表现类似keyvalue的键值对...

C#中HashTable 哈希表 的用法

一,哈希表(Hashtable)简述   在.NET Framework中,Hashtable是System.Collections命名空间提供的一个容器,用于处理和表现类似keyvalue的键值对,...

(转)C# (线程安全的哈希表)Hashtable Synchronized vs SyncRoot

Synchronized vs SyncRoot 我们知道,在.net的一些集合类型中,譬如Hashtable和ArrayList,都有Synchronized静态方法和SyncRoot实例方法,他们...
  • dare_
  • dare_
  • 2013年07月10日 10:30
  • 1521

c#常用集合类使用练习(队列Queue、栈Stack、哈希表Hashtable和动态数组ArrayList)(3):

哈希表Hashtable 哈希表又称散列表,表示键值对的集合; 哈希表保存集合元素时,首先要根据建自动计算哈希代码,以确定该元素的保存位置,再把元素的值放入相应位置所指 向的存储桶中; 查找时...
  • Wood_Du
  • Wood_Du
  • 2017年10月25日 19:26
  • 67

C#技巧—哈希表Hashtable用法

在.NET Framework中,Hashtable是System.Collections命名空间提供的一个容器,用于处理和表现类似key/value的键值对,其中key通常可用来快速查找,同时key...
  • a125138
  • a125138
  • 2012年07月16日 17:40
  • 1146

C#中哈希表(HashTable)的用法详解

C#中哈希表(HashTable)的用法详解 1.  哈希表(HashTable)简述   在.NET Framework中,Hashtable是System.Collec...

C#中哈希表(HashTable)的用法详解

转载自:http://www.cnblogs.com/xpvincent/archive/2013/01/15/2860841.html 哈希表(HashTable)简述在.NET Framework...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:在C#中应用哈希表(Hashtable)
举报原因:
原因补充:

(最多只允许输入30个字)