什么是迭代器
在java中,有很多的數(shù)據(jù)容器,對(duì)于這些的操作有很多的共性。java采用了迭代器來為各種容器提供了公共的操作接口。這樣使得對(duì)容器的遍歷操作與其具體的底層實(shí)現(xiàn)相隔離,達(dá)到解耦的效果。
在iterator接口中定義了三個(gè)方法:
java集合類中map接口下的相關(guān)類并沒有像collection接口的相關(guān)類一樣實(shí)現(xiàn)get()方法,因此在要實(shí)現(xiàn)遍歷輸出的場(chǎng)景中沒法直接用get()方法來取得對(duì)象中的數(shù)據(jù),但java本身提供了另一種遍歷數(shù)據(jù)的方法,即用iterator迭代器,雖然iterator可以用來遍歷讀取數(shù)據(jù),但它本質(zhì)上不是一種方法,它只是一種設(shè)計(jì)模式,它是一個(gè)對(duì)象,一個(gè)“輕量級(jí)”的對(duì)象。下文講講iterator在不同接口中的使用方法:
(一)iterator在collection接口中的使用。
雖然collection接口的相關(guān)類實(shí)現(xiàn)了get()方法,但將iterator用在它們身上仍然是合適的,下面以arraylist為例,討論iterator在collection中的兩中使用方法:
1.配合while()循環(huán)實(shí)現(xiàn)遍歷輸出:
1
2
3
4
5
6
|
arraylist list = new arraylist(); //此處省略list的具體賦值過程 iterator it = list.iterator(); while (it.hasnext()){ system.out.println(it.next()); } |
while()中的判斷條件it.hasnext()用于判斷it中是否還有下一元素,有的話就繼續(xù)循環(huán),輸出語句中的it.next()既可以使“指針”往后走一位,又能將當(dāng)前的元素返回,用于輸出。
2.配合for()循環(huán)實(shí)現(xiàn)遍歷輸出:
1
2
3
4
5
|
arraylist list = new arraylist(); //此處省略list的賦值過程 for (iterator it = list.iterator();it.hasnext();){ system.out.println(it.next()); } |
for()循環(huán)中的使用原理跟while()是一樣的,在此就不再過多贅述。
不過上面的是在一般for()循環(huán)中的使用,我們還可以將之與for each 循環(huán)來代替iterator,因?yàn)閒or each 本身就相當(dāng)于一個(gè)迭代器了:
1
2
3
4
5
|
arraylist list = new arraylist(); //此處同樣省略list的賦值過程 for (object array:list){ system.out.println(array); } |
需要注意的是for each 不適合用來增刪元素,如果單純用來遍歷元素,這種寫法也許會(huì)更簡潔一點(diǎn)。
(二)iterator在map接口中的使用:
下文用hashmap為例,討論迭代器的兩種主要使用方法。
1.與while()的結(jié)合
1
2
3
4
5
6
|
hashmap<k,v> mymap = new hashmap<k,v>(); //省略mymap的的賦值過程 iterator<map.entry<k,v> it=mymap.entryset().iterator(); while (it.hasnext()){ system.out.println(it.next()); } |
//如果想讓輸出更加格式化,可以自己重寫tostring()方法,由于tostring方法的重寫不是本文討論的重點(diǎn),所以暫且不討論。
map接口下的iterator應(yīng)用方法與collection中的略微有些不同,用到了entryset()方法,entryset()用來返回整個(gè)鍵—值對(duì)。
2.與for()的結(jié)合
1
2
3
4
5
|
hashmap<k,v> mymap= new hashmap<k,v>(); //省略mymap的賦值過程 for (iterator<map.entry<k,v>> it=mymap.entryset().iterator();it.hasnext();){ system.out.println(it.next()); } |
有上面幾個(gè)例子的說明,這里就不用繼續(xù)解釋原理了。
同樣這里再貼出for each代替iterator的用法:
1
2
3
4
5
|
hashmap<k,v> mymap= new hashmap<k,v>(); //省略mymap賦值過程 for (object oj:mymap.entryset()){ system.out.println(oj); } |
for each 中同樣要用到entryset()方法,具體如果對(duì)entryset方法有疑問,請(qǐng)自行百度,本文不過多描述。
結(jié)語:由于iterator類封裝在java.util路徑下,所以要使用iterator需先import java.util.iterator;或者import java.util.*;
總結(jié)
以上所述是小編給大家介紹的java中迭代器iterator的使用解析,希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)服務(wù)器之家網(wǎng)站的支持!
原文鏈接:http://www.cnblogs.com/TangMoon/archive/2017/09/24/7589082.html