Java HashMap類
HashMap類使用一個哈希表實現Map接口。這允許基本操作,如get()和put()的執行時間保持恒定,即使對於大型集。
HashMap類支持四種構造函數。第一種形式構造一個默認的哈希映射:
HashMap( )
第二種形式初始化哈希映射使用m的元素:
HashMap(Map m)
第三種形式初始化哈希映射容量的能力:
HashMap(int capacity)
第四種形式初始化雙方的容量,並通過使用它的參數填補了哈希映射的比例:
HashMap(int capacity, float fillRatio)
除了從它的父類繼承的方法,HashMap中定義了以下方法:
SN | 方法及描述 |
---|---|
1 |
void clear() 移除所有映射關係從這個映射中。 |
2 |
Object clone() 返回此HashMap實例的淺表副本:鍵和值本身不被複製。 |
3 |
boolean containsKey(Object key) 如果此映射包含指定鍵的映射關係返回true。 |
4 |
boolean containsValue(Object value) 如果此映射一個或多個鍵映射到指定值返回true。 |
5 |
Set entrySet() 返回此映射中包含的映射關係的集合視圖。 |
6 |
Object get(Object key) 返回指定鍵映射在此標識哈希映射,或者null,如果映射不包含此鍵的值。 |
7 |
boolean isEmpty() 如果此映射不包含鍵 - 值映射關係返回true。 |
8 |
Set keySet() 返回此映射中包含的鍵的set視圖。 |
9 |
Object put(Object key, Object value) 關聯與此映射中的指定鍵指定的值。 |
10 |
putAll(Map m) 複製所有由指定映射的映射到此映射,這些映射關係將替換此映射的所有當前指定映射中鍵的所有映射關係。 |
11 |
Object remove(Object key) 從此映射中移除(如果存在)映射為這個鍵。 |
12 |
int size() 返回鍵 - 值映射關係在這個映射中的數量。 |
13 |
Collection values() 返回此映射中包含的值的collection視圖。 |
例子:
下麵的程序說明了幾個由這個集合所支持的方法:
import java.util.*; public class HashMapDemo { public static void main(String args[]) { // Create a hash map HashMap hm = new HashMap(); // Put elements to the map hm.put("Zara", new Double(3434.34)); hm.put("Mahnaz", new Double(123.22)); hm.put("Ayan", new Double(1378.00)); hm.put("Daisy", new Double(99.22)); hm.put("Qadir", new Double(-19.08)); // Get a set of the entries Set set = hm.entrySet(); // Get an iterator Iterator i = set.iterator(); // Display elements while(i.hasNext()) { Map.Entry me = (Map.Entry)i.next(); System.out.print(me.getKey() + ": "); System.out.println(me.getValue()); } System.out.println(); // Deposit 1000 into Zara's account double balance = ((Double)hm.get("Zara")).doubleValue(); hm.put("Zara", new Double(balance + 1000)); System.out.println("Zara's new balance: " + hm.get("Zara")); } }
這將產生以下結果:
Zara: 3434.34 Mahnaz: 123.22 Daisy: 99.22 Ayan: 1378.0 Qadir: -19.08 Zara's new balance: 4434.34