foreach 是 Java 中的一種語法糖,幾乎每一種語言都有一些這樣的語法糖來方便程序員進(jìn)行開發(fā),編譯期間以特定的字節(jié)碼或特定的方式來對(duì)這些語法進(jìn)行處理。能夠提高性能,并減少代碼出錯(cuò)的幾率。在 Java 中還有比如 泛型、自動(dòng)拆箱、自動(dòng)裝箱、內(nèi)部類、枚舉等等。
foreach 是用來對(duì)數(shù)組或者集合進(jìn)行遍歷的語法。具體語法如下:
1
2
|
for (元素類型 ele : 數(shù)組名/Iterable 實(shí)例){ } |
下面我們用 foreach 來對(duì)數(shù)組和一個(gè)集合進(jìn)行遍歷:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
|
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)容:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
|
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、對(duì)于數(shù)組,foreach 循環(huán)實(shí)際上還是用的普通的 for 循環(huán)
2、對(duì)于集合,foreach 循環(huán)實(shí)際上是用的 iterator 迭代器迭代
注意:如果我們想一邊迭代,一邊刪除集合中的元素,如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
|
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); //一邊迭代一邊刪除 } |
這樣寫會(huì)報(bào)如下錯(cuò)誤:這是一個(gè)并發(fā)修改異常報(bào)錯(cuò)
原因:當(dāng)?shù)鬟\(yùn)行的時(shí)候,在當(dāng)前線程 A 中,會(huì)單獨(dú)的創(chuàng)建一個(gè)線程 B。A 負(fù)責(zé)繼續(xù)迭代,B 線程負(fù)責(zé)刪除。B 線程每次都會(huì)去檢查 A 線程中的元素是否相同,如果不是就會(huì)報(bào)錯(cuò)
因?yàn)樯厦鎰h除的方法是 使用 Collection(ArrayList 的父類) 集合中的 remove()方法。該方法只能從集合中刪除元素,不能把迭代器中的元素也刪除了。
解決辦法:使用 iterator 迭代器中的remove()方法
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
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);//如果你用 集合 方法,那么還是會(huì)報(bào)錯(cuò) } } |
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持服務(wù)器之家。
原文鏈接:http://www.cnblogs.com/ysocean/p/6822679.html?utm_source=tuicool&utm_medium=referral