iterator迭代器用法 對于一個java程序員來說,深入了解迭代器的概念重要嗎?
對于一個java程序員來說,深入了解迭代器的概念重要嗎?首先,讓我們普及迭代器的概念。迭代器,有時稱為游標(biāo),是一種程序設(shè)計的軟件設(shè)計模式。它是一個可以在整個容器(如鏈表或數(shù)組)中訪問的接口。設(shè)計者不需
對于一個java程序員來說,深入了解迭代器的概念重要嗎?
首先,讓我們普及迭代器的概念。迭代器,有時稱為游標(biāo),是一種程序設(shè)計的軟件設(shè)計模式。它是一個可以在整個容器(如鏈表或數(shù)組)中訪問的接口。設(shè)計者不需要關(guān)心容器的內(nèi)容。Java迭代器主要用于容器中,比如數(shù)組列表。
作為一種設(shè)計模式,迭代器可以用來遍歷對象,開發(fā)人員不必了解對象的底層結(jié)構(gòu)。迭代器的使用也非常簡單?,F(xiàn)在讓我們簡要總結(jié)一下使用迭代器的好處。
1. 迭代器可以提供統(tǒng)一的迭代方式。
2. 迭代器還可以以對客戶端透明的方式提供各種迭代。
3. 迭代器提供了一種快速失效機制,以防止多線程環(huán)境下迭代的不安全操作。
由于Java中有許多數(shù)據(jù)容器,而且數(shù)據(jù)容器的操作在很多時候非常常見,所以Java使用迭代器為各種容器提供通用的操作接口。Java的迭代器可以使容器的遍歷操作與底層完全隔離,達到很好的解耦效果。
但是,迭代次數(shù)取決于集合中元素的數(shù)量。刪除或添加集合中的元素時,迭代次數(shù)會發(fā)生變化,將元素插入集合的非結(jié)尾會導(dǎo)致更致命的結(jié)果,這將導(dǎo)致上一次迭代的元素再次訪問,或者某些元素?zé)o法訪問。
java中foreach和迭代器在遍歷List集合,一些情況下為什么能使用集合自動的刪除方法刪除元素?
當(dāng)您是<70時,倒數(shù)第二位是66。您沒有引發(fā)異常,因為以前的列表大小是5。刪除66后,列表大小為4。第一次遍歷列表大小為5的數(shù)組時,指針66位于index=4中。遍歷列表大小為4的數(shù)組時,指針66位于index=4中newlist.size文件()。
ArrayList中的此方法將判斷列表已被讀取,因此不會引發(fā)異常。
1]]2
3
公共布爾hasnext(){
返回光標(biāo)!=size
}
A< 90,第二位變了,列表的大小也變了
看ArrayList的源代碼,調(diào)用這個方法檢查列表的大小是否每次都變,但是這個方法發(fā)生在hasnext方法之后
1
2
3
4
final void checkForComodification(){
if(modCount!=expectedModCount)
拋出新的ConcurrentModificationException()
}