1.增強for循環和iterator遍歷的效果是一樣的,也就說:增強for循環的內部也就是調用iteratoer實現的(可以查看編譯后的文件)。但是增強for循環有些缺點,例如不能在增強循環里動態的刪除集合內容,不能獲取下標等。
2.ArrayList由於使用數組實現,因此下標明確,最好使用普通循環。
3.而對於 LinkedList 由於獲取一個元素,要從頭開始向后找,因此建議使用增強for循環,也就是iterator。
下面的例子可以證明
public static void main(String[] args)
{
List<Integer> list = new ArrayList<Integer>();
for (int i = 0; i < 5000000; i++)
{
list.add(11);
}
long start = System.currentTimeMillis();
int size = list.size();
int c1 = 1;
for (int i = 0; i < size; i++)
{
c1 = list.get(i);
}
System.out.println("for + get(i)方法: " + (System.currentTimeMillis() - start));
long start2 = System.currentTimeMillis();
for (int c2 : list)
{
}
System.out.println("Iterator(foreach)方法:" + (System.currentTimeMillis() - start2));
}
結果:
for + get(i)方法: 94
Iterator(foreach)方法:234
在把ArrayList改為LinkedList,我這里內存溢出了,於是list改成50000
結果:
for + get(i)方法: 6969
Iterator(foreach)方法:0
---------------------
所以在使用的時候適當選擇就好了。
多線程中的區別:
// for (Block b : __blocks) {
// b.onDraw(canvas);
// }
// Iterator<Block> it = __blocks.iterator();
// while(it.hasNext()){
// Block b = it.next();
// b.onDraw(canvas);
// }
for(int i = 0; i < __blocks.size(); i++){
__blocks.get(i).onDraw(canvas);
}
另外外一個線程動態的改變__blocks的大小 只有普通for循環不報錯,其他通過迭代器實現的
是先有一個拷貝,所以真正得到時 ,會報並發修改錯誤。
在單線程中:
增強for不能動態刪除元素,用Iterator能實現。
示例代碼
Map<String, String> map = new HashMap<String, String>();
map.put("1", "a1");
map.put("2", "a2");
map.put("3", "a3");
map.put("4", "a4");
map.put("5", "a5");
for (String key : map.keySet()) {
if ("a2".equals(map.get(key))) {
map.remove(key);
}
}
System.out.println(map.size());
List<String> list = new ArrayList<String>();
list.add("a1");
list.add("a2");
list.add("a3");
list.add("a4");
list.add("a5");
Iterator<String> it = list.iterator();
while (it.hasNext()) {
String v = it.next();
if ("a2".equals(v)) {
it.remove();
}
}
for (String v : list) {
System.out.println(v);
}
}
