HashMap<Integer, String> hashMap = new HashMap();
hashMap.put(2,"aa");
hashMap.put(5,"bb");
// 這里的Entry是Map內部類,所以寫成Map.Entry相當於就是散列表中的鏈表中的Node
Set<Entry<Integer, String>> entrys = hashMap.entrySet(); // 獲取集合中全部的entry對象
Iterator<Entry<Integer, String>> it = entrys.iterator();
while (it.hasNext()) {
Entry<Integer, String> entry = it.next(); // entry里面包含了key和value
Integer key = entry.getKey(); // 獲取到Key
String value = entry.getValue(); // 獲取到值
/** 輸出結果是:
2--aa
5--bb
*/
System.out.println(key + "--" + value);
}
其中hashMap.entrySet()方法的源代碼如下:
public Set<Map.Entry<K,V>> entrySet() {
Set<Map.Entry<K,V>> es;
return (es = entrySet) == null ? (entrySet = new EntrySet()) : es;
}
擴展:從json對象中組裝出來一個hashMap集合
List<Map<String,Object>> rows = new ArrayList<Map<String,Object>>();
for( Object obj : jsonArray ){
JSONObject jObject = ( JSONObject ) obj;
if( obj == null ){
continue;
}
// 實現邏輯是:先取出key放在一個set集合中,也就是去重
Set<String> keySet = jObject.keySet(); //
if( keySet == null || keySet.size() == 0 ){
continue;
}
// 然后又來定義一個HashMap<String,Object>集合,接着又分別遍歷key跟取出key對應的值
Map<String,Object> row = new HashMap<String,Object>( keySet.size() );
for( String key : keySet ){
row.put( key, jObject.get( key )); // 組裝成map集合
}
rows.add( row );
}
