您现在所在的位置: 北风技术专栏 > .Net > Hashtable简介和使用

Hashtable简介和使用

作者:xingkong 发布于:2008年09月23日 15:40

一、简介
1、Hashtable(哈希表)在.NET Framework中,Hashtable是System.Collections命名空间提供的一个容器,用于处理和表现类似key/value的键值对,其中key通常可用来快速查找,同时key是区分大小写;value用于存储对应于key的值。Hashtable中key/value键值对均为object类型,所以Hashtable可以支持任何类型的key/value键值对。
2、Hashtable优点:查找速度快,像上面提到的通过KEY快速查找,因为通过KEY会计算一个唯一的地址(KEY不相同的情况下),而那个地址就存放了VALUE。
Hashtable缺点:对数据量大的时候内存占用大。

二、使用
1、要想使用Hashtable,就需要加入命名空间System.Collections。[using System.Collections]
2、实例化一个Hashtable对象[Hashtable ht=new Hashtable()]
3、可以使用实例化后Hashtable对象如上面的 ht进行添加、删除、查找、排序、遍历。(具体操作请看下面的操作代码)。
三、操作代码(都使用上面已实例化的对象ht)
1、添加元素
ht.Add(key,value) //key、value是任意类型的数据。

2、删除某个元素和所有元素
ht.Remove(key),ht.Clear()
3、查找元素
ht.Contains(key)
4、遍历KEY
foreach(Object key in ht.Keys)
{
Console.WriteLine(key.Tostring());
}

5、遍历VALUE
foreach(Object value in ht.Values)
{
Console.WriteLine(value.Tostring());
}

6、同时遍历KEY,VALUE
foreach(DictionaryEntry de in ht)
{
Console.WriteLine(de.Key)
Console.WriteLine(de.Value)
}

7、排序
我们这里要用到ArrayList集合类,以存放ht所有的KEYS或VALUES
//对KEYS排序
ArrayList akeys = new ArrayList(ht.Keys);
akeys.Sort();
//对VALUES排序
ArrayList akeys = new ArrayList(ht.values);
akeys.Sort();

结束语:Hashtable在查找数据时用处很大,因为速度很快,但用牺牲内存消耗作代价。QQ在查找在线用户的时候就适当的用了Hashtable。大家可以根据场合适当使用。

作者:xingkong
来源:北风技术专栏
原文链接:http://column.ibeifeng.com/xingkong/2008092340.shtml

( 内容完 )

添加收藏到:

您可能还对这些文章感兴趣:

  • ikon999原创:JsUnit测试之一
  • 使用反射简化Swing工具栏菜单按钮子项的设计
  • 认识安全框架acegi(2)
  • 浅谈在Java语言中究竟是传值还是传引用
  • WEB高性能开发(10) - 疯狂的HTML压缩
  • ewebeditor使用教程(一)
  • 如何避免JQuery Dialog的内存泄露
  • 关于中国国产手机游戏
  • 联系我们
  • 如何编出健壮的代码 java编程30条规则
  • 没有评论, 我来评论

    小贴士:评论需要管理员审核后才会显示。请不要发布与国家法律相抵触的言论,北风网将保留追究责任的权利。
    类似“顶”、“沙发”、“支持”之类没有营养的文字,对勤劳贡献的作者来说是令人沮丧的反馈信息。
    请勿到处挖坑绊人、招贴广告。既占空间让人厌烦,又没人会搭理,于人于己都无利。
    如果您发现自己的评论没有被审核或者不见了,请参考以上三条。

    每周之星

    陈臣陈臣

    七年Java和JEE开发经验,JEE应用设计和高级架构师,拥有Sun的多项Java和J2EE方面的技能认证,多年项目经理、技术部经理的管理经验。拥有全面、扎实的Java和JEE理论知识,丰富的JEE应用开发经验。

    更多作者:

  • Adam
  • ikon999
  • jk1234
  • jk2345
  • libin_8745
  • lifengxing
  • taohuang100
  • xingkong
  • 北风
  • 呆子
  • 子晨
  • 小白
  • 张章
  • 张维亮
  • 陈臣
  • 陶宝哥
  • 风风
  • 最新内容

    推荐内容

    标签

    分类