C#入门及进阶|数组和集合(八):HashTable类介绍

在ArrayList集合中,可以使用索引访问元素,如果不能确切知道索引的值,访问就比较困难。HashTable称为哈希表,和ArrayList不同,它利用键/值来存储数据,在哈希表中,每个元素都是一个键/值对,并且是一一对应的,通过"键"就可以得到"值"。如果存储电话号码,通常是姓名和电话号码存在一起,存储时把姓名当作键,号码作为值,通过姓名即可查到电话号码,这就是一个典型的哈希表存储方式。

哈希表常用的属性如下表所示:

|----------|-------------------------|
| 属性名称 | 属性说明 |
| Count | 获取包含在Hashtable中的键/值对的数目 |
| Keys | 获取包含Hashtable中的所有键的集合 |
| Values | 获取包含Hashtable中的所有值的集合 |

哈希表常用的方法如下表所示:

|---------------|---------------------------------------|
| 方法名称 | 方法说明 |
| Add | 将带有指定键和值的元素添加到Hashtable中 |
| Clear | 从Hashtable中移除所有元素 |
| Contains | 确定Hashtable是否包含特定键 |
| GetEnumerator | 返回IDictionaryEnumerator,可以遍历Hashtable |
| Remove | 从Hashtable中移除带有指定键的元素 |

Hashtable类提供了15个重载的构造函数,比较常用的4种Hashtable构造函

数声明如下。

(1)使用默认的初始容量、加载因子、哈希代码提供程序和比较器来初始化 Hashtable类的实例:

cs 复制代码
public Hashtable();

(2)使用指定容量、默认加载因子、默认哈希代码提供程序和比较器来初始化Hashtable类的实例:

cs 复制代码
public Hashtable(int capacity);

(3)使用指定的容量,加载因子来初始化Hashtable类的实例:

cs 复制代码
public Hashtable(int capacity, float loadFactor);

(4)通过将指定字典中的元素复制到新的 Hashtable 对象中,初始化 Hashtable 类的一个新实例。新 Hashtable 对象的初始容量等于复制的元素数,并且使用默认的加载因子、哈希代码提供程序和比较器:

cs 复制代码
public Hashtable(IDictionary d);

下面是一个初始化一个新的Hashtable对象并向其中添加元素并输出的代码实例:

cs 复制代码
static void Main(string[] args)
{
    // Creates and initializes a new Hashtable.
    Hashtable myHT = new Hashtable();
    myHT.Add( "one", "Cristiano Ronaldo" );
    myHT.Add( "two", "is" );
    myHT.Add( "three", "the" );
    myHT.Add( "four", "best" );
    // Displays the Hashtable.
    Console.WriteLine( "The Hashtable contains the following:" );
    foreach ( DictionaryEntry de in myHT )
        Console.WriteLine( "\t{0}:\t{1}", de.Key, de.Value);
}
相关推荐
计算机安禾2 分钟前
【C语言程序设计】第38篇:链表数据结构(二):链表的插入与删除操作
c语言·开发语言·数据结构·c++·算法·链表
oem1105 分钟前
C++中的适配器模式
开发语言·c++·算法
lly2024065 分钟前
jQuery 隐藏/显示
开发语言
青木川崎9 分钟前
设计模式之面试题
java·开发语言·设计模式
空空潍10 分钟前
Java核心基础语法:从原理到实战,夯实Java开发基石
java·开发语言
jing-ya10 分钟前
day 57 图论part9
java·开发语言·数据结构·算法·图论
huohuopro10 分钟前
详解ThreadLocal的使用
java·开发语言·jvm
2401_8942419211 分钟前
C++与Rust交互编程
开发语言·c++·算法
格林威16 分钟前
工业相机图像高速存储(C++版):RAID 0 NVMe SSD 阵列方法,附堡盟相机实战代码!
开发语言·c++·人工智能·数码相机·opencv·计算机视觉·视觉检测
froginwe1119 分钟前
Go 语言类型转换
开发语言