Hashtable是Java中提供的一种哈希表数据结构的实现,它实现了Map接口,采用键/值对的方式存储数据,并根据键的哈希值存储和访问数据,具有快速查找的优势。
Hashtable是线程安全的,因为它的所有方法都是同步的,但这也导致在高并发情况下性能较低,在JDK1.5之后,Java提供了ConcurrentHashMap来替代Hashtable。
Hashtable提供了两种构造方式:
java
Hashtable<Key, Value> table = new Hashtable<Key, Value>();
java
Hashtable<Key, Value> table = new Hashtable<Key, Value>(initialCapacity, loadFactor);
使用put(key, value)
方法添加元素,如果key值已存在,则会覆盖原有元素的值。
示例:
Hashtable<String, Integer> table = new Hashtable<String, Integer>();
table.put("apple", 1);
table.put("banana", 2);
// 输出: {banana=2, apple=1}
System.out.println(table);
使用get(key)
方法获取元素的值,若key值不存在,则返回null。
示例:
Hashtable<String, Integer> table = new Hashtable<String, Integer>();
table.put("apple", 1);
table.put("banana", 2);
// 输出:2
System.out.println(table.get("banana"));
// 输出:null
System.out.println(table.get("orange"));
使用remove(key)
方法删除指定key值的元素,如果key值不存在,则不做任何操作。
示例:
Hashtable<String, Integer> table = new Hashtable<String, Integer>();
table.put("apple", 1);
table.put("banana", 2);
table.remove("banana");
// 输出:{apple=1}
System.out.println(table);
使用containsKey(key)
方法判断指定key值的元素是否存在,如果存在则返回true,否则返回false。
示例:
Hashtable<String, Integer> table = new Hashtable<String, Integer>();
table.put("apple", 1);
table.put("banana", 2);
// 输出:true
System.out.println(table.containsKey("apple"));
// 输出:false
System.out.println(table.containsKey("orange"));
Hashtable是Java中的一个哈希表数据结构的实现,它提供了多种方法来添加、获取、删除、判断元素是否存在等操作。虽然它是线程安全的,但在高并发情况下性能较低,建议使用ConcurrentHashMap来替代。