Hashtable是微软.Net开发框架中经常使用的key/value键值对容器。Hashtable中文称作哈希表,也叫散列表,是根据key和value进行访问存储的数据结构。是把key和value映射到数组中的一个位置来访问记录,以加快查找速度。映射函数叫散列函数,存放记录的数组叫散列表。在.Net中key和value均为object类,能存储所有类型。所以对于一些类型需要强制转换。另外key对大小写敏感,区分大小写。
一、基本操作
Hashtable的命名空间
System.Collections,通过using进行引入。
//实例化Hashtable
Hashtable hashTable = new Hashtable();
//增加元素
hashTable.Add("1", "案秀云");
hashTable.Add("2", "案秀云-解决方案库");
hashTable.Add("2", "案秀云-IT知识库");
//删除元素
hashTable.Remove("1");
//删除所有元素
hashTable.Clear();
//元素个数
int count=hashTable.Count;
//判断是否包含key
Boolean isKey= hashTable.ContainsKey("1");
//判断是否包含value
Boolean isValue= hashTable.ContainsValue("案秀云");
二、Hashtable的遍历
Hashtable的常用遍历分为键key遍历、值遍历和键值对遍历。
//key的遍历
foreach (String key in hashTable.Keys)
{
Console.WriteLine(hashTable[key].ToString());
}
//value的遍历
foreach (String value in hashTable.Values)
{
Console.WriteLine(value);
}
//键值对KeyValuePair<T,K>遍历
foreach (KeyValuePair<String , String > kv in hashTable)
{
Console.WriteLine(kv.Key + kv.Value);
}
三、Hashtable排序
有时候需要通过key对Hashtable进行排序,而Hashtable由于本身的实现没办法进行直接进行排序。这里可以通过变通的方法进行排序。
//实例化一个ArrayList对象,并把Hashtable的keys进行赋值
ArrayList akeys = new ArrayList(hashTable.Keys);
//按Key字母顺序进行排序,ArrayList Sort也可以指定范围进行排序
akeys.Sort();
//排序后的遍历输出
foreach (string skey in akeys)
{
Console.WriteLine(hashTable[skey]);
}
Hashtable本身并不支持排序,程序中如果允许可以用Dictionary进行替换。
版权声明:本文为mpegfour原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。