hashtable使用【转贴】

一,哈希表(Hashtable)简述

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

 
### 回答1: Java中的Hashtable是一种基于哈希表的数据结构,用于存储键值对。它的使用方法如下: 1. 创建Hashtable对象: Hashtable<String, Integer> hashtable = new Hashtable<String, Integer>(); 2. 添加键值对: hashtable.put("key1", 1); hashtable.put("key2", 2); hashtable.put("key3", 3); 3. 获取值: int value = hashtable.get("key1"); 4. 判断是否包含某个键: boolean containsKey = hashtable.containsKey("key1"); 5. 判断是否包含某个值: boolean containsValue = hashtable.containsValue(1); 6. 删除键值对: hashtable.remove("key1"); 7. 获取所有键: Enumeration<String> keys = hashtable.keys(); 8. 获取所有值: Enumeration<Integer> values = hashtable.elements(); 注意:Hashtable是线程安全的,但是在多线程环境下,使用ConcurrentHashMap会更好。 ### 回答2: Java Hashtable是一个非常实用的数据结构,因为它可以将键和值的对映射起来,快速地在哈希表中查找和存储数据。要在Java中使用Hashtable,需要知道以下几个方面: 1. 创建Hashtable对象 要创建一个Hashtable对象,应该在Java中使用关键字“new”和Hashtable类名称,并将它们作为构造函数的参数。例如,要创建一个Hashtable对象,代码如下所示: Hashtable<String, String> hashtable = new Hashtable<String, String>(); 注意,这个语句通过使用String”类型的键和值来创建了一个Hashtable对象。如果不指定键和值的类型,就会得到一个“Object”类型的Hashtable,这可能会导致类型转换问题。 2. 添加键和值 要在Hashtable中添加一个键和值,可以使用“put”方法。这个方法需要一个键和一个值作为参数,并将它们添加到Hashtable中。例如: hashtable.put("key1", "value1"); hashtable.put("key2", "value2"); hashtable.put("key3", "value3"); 3. 获取值 使用“get”方法可以获取Hashtable中的值。这个方法需要一个键作为参数,并返回与该键相关联的值。例如: String value1 = hashtable.get("key1"); String value2 = hashtable.get("key2"); String value3 = hashtable.get("key3"); 4. 删除键和值 要从Hashtable中删除一个键和值,可以使用“remove”方法。这个方法需要一个键作为参数,并删除与该键相关联的键和值。例如: hashtable.remove("key1"); 5. 遍历Hashtable 要遍历Hashtable中的键和值,可以使用“entrySet”和“for”循环。例如: Set<Entry<String, String>> set = hashtable.entrySet(); for (Entry<String, String> entry : set) { String key = entry.getKey(); String value = entry.getValue(); System.out.println("Key: " + key + ", Value: " + value); } 在上面的代码中,首先使用“entrySet”方法获取Hashtable中的所有键和值的集合。然后,循环遍历集合,并使用“getKey”和“getValue”方法获取每个键和值。 总之,Java Hashtable是一个非常实用的数据结构,可以快速地在哈希表中查找和存储数据。要使用Hashtable,需要创建Hashtable对象、添加键和值、获取值、删除键和值以及遍历Hashtable。 ### 回答3: Java Hashtable 是一个基于哈希表实现的 Map 接口,它可用于存储 key-value 键值对,其中每个键都是唯一的。与 HashMap 不同,Hashtable 是线程安全的,它的所有方法都是同步的,因此可以在多线程环境下使用,并且在性能方面与 HashMap 相近。 Java Hashtable 的基本用法如下: 1. 创建 Hashtable 对象: Hashtable<String, String> hashtable = new Hashtable<>(); 其中,"<String, String>" 表示键和值都是字符串类型,也可以使用其他数据类型,如 Integer、Double 等。 2. 添加元素: 添加元素可以使用 put() 方法: hashtable.put("key", "value"); 其中,"key" 表示键,"value" 表示值。 3. 获取元素: 获取元素可以使用 get() 方法: String value = hashtable.get("key"); 其中,"key" 表示键,"value" 表示值。 4. 删除元素: 删除元素可以使用 remove() 方法: hashtable.remove("key"); 其中,"key" 表示键。 5. 遍历元素: 遍历元素可以使用 Enumeration 或者 Iterator: (1)使用 Enumeration 遍历: Enumeration<String> keys = hashtable.keys(); while (keys.hasMoreElements()) { String key = keys.nextElement(); String value = hashtable.get(key); } 其中,keys() 方法返回了一个键的 Enumeration 对象,可以使用 hasMoreElements() 和 nextElement() 方法遍历所有键值对。 (2)使用 Iterator 遍历: Iterator<Map.Entry<String, String>> iterator = hashtable.entrySet().iterator(); while (iterator.hasNext()) { Map.Entry<String, String> entry = iterator.next(); String key = entry.getKey(); String value = entry.getValue(); } 其中,entrySet() 方法返回了一个包含所有键值对的 Set 对象,可以使用 iterator() 方法返回一个迭代器,然后使用 hasNext() 和 next() 方法遍历所有键值对。 以上就是 Java Hashtable 的基本用法,除了以上方法之外,Hashtable 还包含了其它一些重要的方法,如 contains、size() 等,可以根据实际需要使用。注意,在多线程环境下使用 Hashtable 时,需要使用 synchronized 或者 ConcurrentHashMap 等线程安全的集合类。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

singye

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值