天天看點

Java中的增強 for 循環 foreach

Java 的 foreach 循環使用

  foreach 是 Java 中的一種文法糖,幾乎每一種語言都有一些這樣的文法糖來友善程式員進行開發,編譯期間以特定的位元組碼或特定的方式來對這些文法進行處理。能夠提高性能,并減少代碼出錯的幾率。在 Java 中還有比如 泛型、自動拆箱、自動裝箱、内部類、枚舉等等。

  foreach 是用來對數組或者集合進行周遊的文法。具體文法如下:

for(元素類型 ele : 數組名/Iterable 執行個體){
 
}
      

  下面我們用 foreach 來對數組和一個集合進行周遊:

     int [] array = {1,2,3};
	for(int i : array){
	  System.out.println(i);
	}
		
	List list = new ArrayList();
	list.add(1);
	list.add(2);
	list.add(3);
	for(Object obj : list){
		System.out.println(obj);
	}
      

  然後我們可以通過反編譯工具,檢視 class 檔案内容:

     int array[] = {1,2,3};
        int [] array$ = array;
        for(int len$ = array$.length, i$ = 0; i$<len$; ++i$ )
        {
            int i = array$[i$];
            {
                System.out.println(i);
            }
        }
        
        
        List list = new ArrayList();
        list.add(1);
        list.add(2);
        list.add(3);
        for(java.util.Iterator i$ = list.iterator(); i$.hasNext();)
        {
            String s = (String) i$.next();
            {
                System.out.println(s);
            }
        }
      

  很明顯:

    1、對于數組,foreach 循環實際上還是用的普通的 for 循環

     2、對于集合,foreach 循環實際上是用的 iterator 疊代器疊代

注意:如果我們想一邊疊代,一邊删除集合中的元素,如下:

    List list = new ArrayList();
    list.add(1);
    list.add(2);
       list.add(3);
    for(Object obj : list){
	  System.out.println(obj);
	  list.remove(obj);  //一邊疊代一邊删除
    }
      

  這樣寫會報如下錯誤:這是一個并發修改異常報錯

Java中的增強 for 循環 foreach

原因:當疊代器運作的時候,在目前線程 A 中,會單獨的建立一個線程 B。A 負責繼續疊代,B 線程負責删除。B 線程每次都會去檢查 A 線程中的元素是否相同,如果不是就會報錯

Java中的增強 for 循環 foreach

因為上面删除的方法是 使用 Collection(ArrayList 的父類) 集合中的 remove()方法。該方法隻能從集合中删除元素,不能把疊代器中的元素也删除了。

解決辦法:使用 iterator 疊代器中的remove()方法

  Iterator it = list.iterator();
  while(it.hasNext()){
    Object obj = it.next();
    System.out.println(obj);
    if(obj.equals(1)){
	  it.remove();//這裡是用 疊代器的 remove() 方法

       //list.remove(obj); 
       //如果你用 集合 方法,那麼還是會報錯
    }	
  }      

  

作者:IT可樂

出處:http://www.cnblogs.com/ysocean/

資源:微信搜【IT可樂】關注我,回複 【電子書】有我特别篩選的免費電子書。

本文版權歸作者所有,歡迎轉載,但未經作者同意不能轉載,否則保留追究法律責任的權利。