1.map的靜態初始化,以及map遍歷的幾種方法:
package com.cy.test; import java.util.HashMap; import java.util.Iterator; import java.util.Map; import java.util.Map.Entry; public class Test { public static void main(String[] args) { Map<String, Integer> map = new HashMap<String, Integer>(){ { put("zh", 1); put("en", 2); put("zh_CN", 1); put("en_US", 2); } }; /** * 方法一 使用Iterator遍歷 * 該種方式看起來冗余卻有其優點所在。 * 首先,在老版本java中這是惟一遍歷map的方式。 * 另一個好處是,你可以在遍歷時調用iterator.remove()來刪除entries,另兩個方法則不能,根據javadoc的說明,如果 * 在for-each遍歷中嘗試使用此方法,結果是不可預測的。 * 從性能方面看,該方法類同於for-each遍歷(即方法二)的性能。 */ Iterator<Entry<String, Integer>> it = map.entrySet().iterator(); while(it.hasNext()){ Entry<String, Integer> entry = it.next(); System.out.println("key:" + entry.getKey() + "----" + entry.getValue()); } /** * 方法二 在for-each循環中使用entries來遍歷 * 這是最常見的並且在大多數情況下也是最可取的遍歷方式。在鍵值都需要時使用。 * 如果你遍歷的是一個空的map對象,for-each循環將拋出NullPointerException */ for(Map.Entry<String, Integer> entry : map.entrySet()){ System.out.println("Key = " + entry.getKey() + ", Value = " + entry.getValue()); } /** * 方法三 在for-each循環中遍歷keys或values。 * 該方法比entrySet遍歷在性能上稍好(快了10%),而且代碼更加干凈。 */ for(String key : map.keySet()){ System.out.println("Key = " + key); } for(Integer value : map.values()){ System.out.println("Value = " + value); } /** * 方法四 通過鍵找值遍歷(效率低) * 實際上它相當慢且無效率。因為從鍵取值是耗時的操作 * 盡量避免使用。 */ for (String key : map.keySet()) { Integer value = map.get(key); System.out.println("Key = " + key + ", Value = " + value); } } }
使用Map.isEmpty()判斷map是不是一個空的集合。
2.List的靜態初始化:
public static void main(String[] args) { //方式1 List<String> list = new ArrayList<String>(){ { add("string1"); add("string2"); add("string3"); } }; //方式2 List<String> list2 = new ArrayList<String>(Arrays.asList("Ryan", "Julie", "Bob")); }
3.