C# 哈希表(Hashtable)用法笔记

作者: 小明yz | 来源:发表于2017-07-11 12:52 被阅读140次

一、什么是Hashtable?

Hashtable 类代表了一系列基于键的哈希代码组织起来的键/值对。它使用键来访问集合中的元素。

当您使用键访问元素时,则使用哈希表,而且您可以识别一个有用的键值。哈希表中的每一项都有一个键/值对。键用于访问集合中的项目

二、Hashtable 的属性

1、Count 获取 Hashtable 中包含的键值对个数。

2、IsFixedSize   获取一个值,表示 Hashtable 是否具有固定大小。

3、IsReadOnly    获取一个值,表示 Hashtable 是否只读。

4、Item  获取或设置与指定的键相关的值。

5、Keys  获取一个 ICollection,包含 Hashtable 中的键。

6、Values    获取一个 ICollection,包含 Hashtable 中的值。

三、Hashtable 的方法

在C#中使用需要引用

using System.Collections;

using System.Collections.Generic;

这两个命名空间

1、  public virtual void Add( object key, object value );

用途: 向 Hashtable 添加一个带有指定的键和值的元素。

2、public virtual void Clear();

用途:从 Hashtable 中移除所有的元素。

3、public virtual bool ContainsKey( object key );

用途:判断 Hashtable 是否包含指定的键。

4、public virtual bool ContainsValue( object value );

用途:判断 Hashtable 是否包含指定的值。

5、public virtual void Remove( object key );

用途:从 Hashtable 中移除带有指定的键的元素。

四、HashTable的应用场景

1、某些数据会被高频率查询

2、数据量很大

3、查询字段包含字符串类型

4、数据类型不唯一

五、HashTable简单用法实例

class Program

{

static void Main(string[] args)

{

// 创建一个Hashtable实例

Hashtable ht=new Hashtable();

// 添加keyvalue键值对

ht.Add("A","1");

ht.Add("B","2");

ht.Add("C","3");

ht.Add("D","4");

// 遍历哈希表只能用foreach来遍历,因为Hashtable不能用索引访问

//遍历key

foreach(Object item in ht.Keys)

{

Console.WriteLine((string)item);

}

//遍历value

foreach(Object item in ht.Value)

{

Console.WriteLine((string)item);

}

foreach (DictionaryEntry de in ht)

{

Console.WriteLine("Key -- {0}; Value --{1}.", de.Key, de.Value);

}

// 哈希表排序

ArrayList akeys=new ArrayList(ht.Keys);

akeys.Sort();

foreach (string skey in akeys)

{

Console.WriteLine("{0, -15} {1, -15}", skey, ht[skey]);

}

// 判断哈希表是否包含特定键,其返回值为true或false

if (ht.Contains("A"))

Console.WriteLine(ht["A"]);

// 给对应的键赋值

ht["A"] ="你好";

// 移除一个keyvalue键值对

ht.Remove("C");

// 遍历哈希表

foreach (DictionaryEntry de in ht)

{

Console.WriteLine("Key -- {0}; Value --{1}.", de.Key, de.Value);

}

// 移除所有元素

ht.Clear();

// 此处将不会有任何输出

Console.WriteLine(ht["A"]);

Console.ReadKey();

}

}

公众号:原文

相关文章

  • C#中HashTable用法和Dictionary比较

    一、哈希表(Hashtable)用法 哈希表(HashTable)简述Hashtable是System.Colle...

  • C# 哈希表(Hashtable)用法笔记

    一、什么是Hashtable? Hashtable 类代表了一系列基于键的哈希代码组织起来的键/值对。它使用键来访...

  • C#之数据结构(下)

    哈希表: Hashtable. (也叫散列表)无序. 哈希表(Hashtable) HashSet. 由一对(ke...

  • 哈希表和链表

    优秀文章:Chapter: 散列表(哈希表) 一、哈希表 哈希表hashtable(key,value) 就是把K...

  • 哈希表

    映射(Map) 和 集合(Set) 哈希表(HashTable)、哈希函数(Hash Function)、哈希碰撞...

  • 2019 算法面试相关(leetcode)--哈希表

    哈希表相关的原理可以参考下:浅谈哈希表(HashTable)深入理解哈希表哈希表的理解理解HashSet及使用 哈...

  • 哈希表(Hashtable)

    请看下回分解

  • 哈希表(HashTable)

    1.整型哈希函数的设计小范围正整数直接使用小范围负整数整体进行偏移大整数,通常做法是"模一个素数" 2.浮点型哈希...

  • 哈希表 - HashTable

    基本概念 哈希表是一种特殊的数据结构,通过索引,能快速的查找到某个元素。 设计原理 通过哈希函数,将key映射到v...

  • 3.11

    1.HashMap和HashTable区别HashMap基于哈希表的Map实现,HashTable基于Dicito...

网友评论

    本文标题:C# 哈希表(Hashtable)用法笔记

    本文链接:https://www.haomeiwen.com/subject/puzphxtx.html