注意:
不要在foreach循環里進行元素的remove/add操作。remove元素請使用Iterator方式,如果並發操作,需要對Iterator對象加鎖。
Java 8之前
List
// List
List<String> list = new ArrayList<>(6);
list.add("1");
list.add("2");
for (Iterator<String> iterator = list.iterator();iterator.hasNext();){
String item = iterator.next();
System.out.println(item);
if (刪除元素的條件) {
iterator.remove();
}
}
Map
規范:
使用 entrySet遍歷 Map類集合 KV,而不是 keySet方式進行遍歷。
說明:keySet 其實是遍歷了2 次,一次是轉為 Iterator 對象,另一次是從 hashMap 中取出key所對應的 value。而 entrySet 只是遍歷了一次就把 key和value都放到了entry中,效率更高。如果是 JDK8,使用 Map.forEach 方法。
正例:values()返回的是 V值集合,是一個 list 集合對象;keySet()返回的是K 值集合,是一個 Set 集合對 象;entrySet()返回的是K-V值組合集合。
// Map 使用 entrySet
HashMap<String,Integer> map = new HashMap<>(6);
map.put("a",1);
map.put("b",2);
for (Map.Entry<String,Integer> entry : map.entrySet()){
System.out.println("key:"+entry.getKey()+"\tvalue:"+entry.getValue());
}
Java 8 之后
使用forEach() + Lambda 表達式
// List
List<String> list = new ArrayList<>(6);
list.add("1");
list.add("2");
list.forEach(v -> System.out.println(v));
// Map
// Map
HashMap<String,Integer> map = new HashMap<>(6);
map.put("a",1);
map.put("b",2);
map.forEach((k,v) -> {
System.out.println("key:"+k+"\tvalue:"+v);
});
使用forEach + Lambda表達式之后,代碼量減少了很多。
更多文章:www.ipooli.com
掃碼關注公眾號《ipoo》