热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

什么是哈希表(Hashtable)

摘自(www.pconline.com.cn)一,哈希表(Hashtable)简述?在.NETFramework中,Hashtable是System.Collections命名空间提供的一个容器,

摘自(www.pconline.com.cn)

,哈希表(Hashtable)简述
? .NET Framework中,HashtableSystem.Collections命名空间提供的一个容器,用于处理和表现类似key/value的键值对,其中key通常可用来快速查找,同时key是区分大小写;value用于存储对应于key的值。Hashtablekey/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")) //
判断哈希表是否包含特定键,其返回值为truefalse
??? 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]);//
排序后输出
?}


推荐阅读
  • 我有一个xml文件,里面的数据想放入自定义类里存入HashTable里面,不知道有没有哪为高手有这方面的例子,希望能解小弟一时之困!谢谢! ... [详细]
  • 模板引擎StringTemplate的使用方法和特点
    本文介绍了模板引擎StringTemplate的使用方法和特点,包括强制Model和View的分离、Lazy-Evaluation、Recursive enable等。同时,还介绍了StringTemplate语法中的属性和普通字符的使用方法,并提供了向模板填充属性的示例代码。 ... [详细]
  • 本文分享了一个关于在C#中使用异步代码的问题,作者在控制台中运行时代码正常工作,但在Windows窗体中却无法正常工作。作者尝试搜索局域网上的主机,但在窗体中计数器没有减少。文章提供了相关的代码和解决思路。 ... [详细]
  • Java容器中的compareto方法排序原理解析
    本文从源码解析Java容器中的compareto方法的排序原理,讲解了在使用数组存储数据时的限制以及存储效率的问题。同时提到了Redis的五大数据结构和list、set等知识点,回忆了作者大学时代的Java学习经历。文章以作者做的思维导图作为目录,展示了整个讲解过程。 ... [详细]
  • 本文讨论了一个关于cuowu类的问题,作者在使用cuowu类时遇到了错误提示和使用AdjustmentListener的问题。文章提供了16个解决方案,并给出了两个可能导致错误的原因。 ... [详细]
  • Java程序设计第4周学习总结及注释应用的开发笔记
    本文由编程笔记#小编为大家整理,主要介绍了201521123087《Java程序设计》第4周学习总结相关的知识,包括注释的应用和使用类的注释与方法的注释进行注释的方法,并在Eclipse中查看。摘要内容大约为150字,提供了一定的参考价值。 ... [详细]
  • 本文讨论了微软的STL容器类是否线程安全。根据MSDN的回答,STL容器类包括vector、deque、list、queue、stack、priority_queue、valarray、map、hash_map、multimap、hash_multimap、set、hash_set、multiset、hash_multiset、basic_string和bitset。对于单个对象来说,多个线程同时读取是安全的。但如果一个线程正在写入一个对象,那么所有的读写操作都需要进行同步。 ... [详细]
  • 本文整理了Java面试中常见的问题及相关概念的解析,包括HashMap中为什么重写equals还要重写hashcode、map的分类和常见情况、final关键字的用法、Synchronized和lock的区别、volatile的介绍、Syncronized锁的作用、构造函数和构造函数重载的概念、方法覆盖和方法重载的区别、反射获取和设置对象私有字段的值的方法、通过反射创建对象的方式以及内部类的详解。 ... [详细]
  • EPPlus绘制刻度线的方法及示例代码
    本文介绍了使用EPPlus绘制刻度线的方法,并提供了示例代码。通过ExcelPackage类和List对象,可以实现在Excel中绘制刻度线的功能。具体的方法和示例代码在文章中进行了详细的介绍和演示。 ... [详细]
  • HashMap的相关问题及其底层数据结构和操作流程
    本文介绍了关于HashMap的相关问题,包括其底层数据结构、JDK1.7和JDK1.8的差异、红黑树的使用、扩容和树化的条件、退化为链表的情况、索引的计算方法、hashcode和hash()方法的作用、数组容量的选择、Put方法的流程以及并发问题下的操作。文章还提到了扩容死链和数据错乱的问题,并探讨了key的设计要求。对于对Java面试中的HashMap问题感兴趣的读者,本文将为您提供一些有用的技术和经验。 ... [详细]
  • HashTable与ConcurrentHashMap均可实现HashMap的功能,对外提供了键值对存储的数据结构。但是在内部结构及实现上有何区别,性能上的差异到底在哪里又是如何导致的 ... [详细]
  • 类Hashtable<K,V>所有已实现的接口:Serializable,Cloneable,Map<K,V>此类实现一个哈希表,该哈希表将键映 ... [详细]
  • 一、HashMap1.HashMap概述:HashMap是基于哈希表的Map接口的非同步实现。此实现提供所有可选的映射操作,并允许使用null值和null键。此类不保证映射的顺序,特别是 ... [详细]
  • 常用API-Hashtable类及其与HashMap、HashSet的区别转载请表明出处:http:blog.csdn.netu012637501(嵌入式_小J的天空)一、Hashtable&l ... [详细]
  • Iamtryingtomakeaclassthatwillreadatextfileofnamesintoanarray,thenreturnthatarra ... [详细]
author-avatar
韩韩韩韩韩海
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有