詳解Java中的增強 for 循環(huán) foreach
foreach 是 Java 中的一種語法糖,幾乎每一種語言都有一些這樣的語法糖來方便程序員進行開發(fā),編譯期間以特定的字節(jié)碼或特定的方式來對這些語法進行處理。能夠提高性能,并減少代碼出錯的幾率。在 Java 中還有比如 泛型、自動拆箱、自動裝箱、內(nèi)部類、枚舉等等。
foreach 是用來對數(shù)組或者集合進行遍歷的語法。具體語法如下:
for(元素類型 ele : 數(shù)組名/Iterable 實例){ }
下面我們用 foreach 來對數(shù)組和一個集合進行遍歷:
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 文件內(nèi)容:
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、對于數(shù)組,foreach 循環(huán)實際上還是用的普通的 for 循環(huán)
2、對于集合,foreach 循環(huán)實際上是用的 iterator 迭代器迭代
注意:如果我們想一邊迭代,一邊刪除集合中的元素,如下:
List list = new ArrayList(); list.add(1);<br> list.add(2); list.add(3); for(Object obj : list){ System.out.println(obj); list.remove(obj); //一邊迭代一邊刪除 }
這樣寫會報如下錯誤:這是一個并發(fā)修改異常報錯
原因:當(dāng)?shù)鬟\行的時候,在當(dāng)前線程 A 中,會單獨的創(chuàng)建一個線程 B。A 負責(zé)繼續(xù)迭代,B 線程負責(zé)刪除。B 線程每次都會去檢查 A 線程中的元素是否相同,如果不是就會報錯
因為上面刪除的方法是 使用 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() 方法<br> //list.remove(obj);//如果你用 集合 方法,那么還是會報錯 } }
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
關(guān)于Mybatis與JPA的優(yōu)缺點說明
這篇文章主要介紹了關(guān)于Mybatis與JPA的優(yōu)缺點說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-06-06Spring Cloud Hystrix 服務(wù)容錯保護的原理實現(xiàn)
這篇文章主要介紹了Spring Cloud Hystrix 服務(wù)容錯保護的原理實現(xiàn),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2019-05-05Java如何使用遞歸查詢多級樹形結(jié)構(gòu)數(shù)據(jù)(多級菜單)
這篇文章主要介紹了Java如何使用遞歸查詢多級樹形結(jié)構(gòu)數(shù)據(jù)(多級菜單),具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-07-07