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);
}
相关推荐
百***92656 分钟前
java进阶1——JVM
java·开发语言·jvm
杜子不疼.18 分钟前
【C++】 map/multimap底层原理与逻辑详解
开发语言·c++
司铭鸿18 分钟前
数学图论的艺术:解码最小公倍数图中的连通奥秘
运维·开发语言·算法·游戏·图论
Cocktail_py23 分钟前
JS如何调用wasm
开发语言·javascript·wasm
饮长安千年月30 分钟前
玄机-第八章 内存马分析-java03-fastjson
开发语言·python·安全·web安全·网络安全·应急响应
MediaTea1 小时前
Python 第三方库:OpenPyXL(Excel 文件读写与操作)
开发语言·python·excel
点云SLAM1 小时前
C++ 中dynamic_cast使用详解和实战示例
开发语言·c++·类型转换·dynamic_cast·c++多态·c++继承
CodeByV2 小时前
【C++】C++11:右值引用和移动语义
开发语言·c++
一水鉴天2 小时前
整体设计 全面梳理复盘 之37 元级自动化引擎三体项目(Designer/Master/Transformer)划分确定 + 自用规划工具(增强版)
开发语言·算法·transformer·公共逻辑
自学互联网2 小时前
python爬虫入门案例day05:Pexels
开发语言·爬虫·python