java java中foreach和迭代器在遍歷List集合,一些情況下為什么能使用集合自動的刪除方法刪除元素?
java中foreach和迭代器在遍歷List集合,一些情況下為什么能使用集合自動的刪除方法刪除元素?當您是<70時,倒數(shù)第二位是66。您沒有引發(fā)異常,因為以前的列表大小是5。刪除66后,列表大小
java中foreach和迭代器在遍歷List集合,一些情況下為什么能使用集合自動的刪除方法刪除元素?
當您是<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(){
返回光標!=size
}
A< 90,第二位變了,列表的大小也變了
看ArrayList的源代碼,調(diào)用這個方法檢查列表的大小是否每次都變,但是這個方法發(fā)生在hasnext方法之后
1
2
3
4
首先是final void,讓我們推廣迭代器的概念。迭代器,有時稱為游標,是一種程序設計的軟件設計模式。它是一個可以在整個容器(如鏈表或數(shù)組)中訪問的接口。設計者不需要關心容器的內(nèi)容。Java迭代器主要用于容器中,比如數(shù)組列表。
作為一種設計模式,迭代器可以用來遍歷對象,開發(fā)人員不必了解對象的底層結構。迭代器的使用也非常簡單?,F(xiàn)在讓我們簡要總結一下使用迭代器的好處。
1. 迭代器可以提供統(tǒng)一的迭代方式。
2. 迭代器還可以以對客戶端透明的方式提供各種迭代。
3. 迭代器提供了一種快速失效機制,以防止多線程環(huán)境下迭代的不安全操作。
由于Java中有許多數(shù)據(jù)容器,而且數(shù)據(jù)容器的操作在很多時候非常常見,所以Java使用迭代器為各種容器提供通用的操作接口。Java的迭代器可以使容器的遍歷操作與底層完全隔離,達到很好的解耦效果。
但是,迭代次數(shù)取決于集合中元素的數(shù)量。刪除或添加集合中的元素時,迭代次數(shù)會發(fā)生變化,將元素插入集合的非結尾會導致更致命的結果,這將導致上一次迭代的元素再次訪問,或者某些元素無法訪問。
對于一個java程序員來說,深入了解迭代器的概念重要嗎?
事實上,嚴格來說,迭代是一種設計模式。迭代的目的是遍歷某一類型數(shù)據(jù)集的內(nèi)容,而不知道該類型數(shù)據(jù)的數(shù)據(jù)結構。
實現(xiàn)思想是定義一個迭代器接口,它至少聲明兩個方法:hasnext()和next()。通過hasnext()判斷是否有遍歷元素,并通過next()返回遍歷元素。對于具體的實現(xiàn),我們可以根據(jù)不同的需求創(chuàng)建不同的實現(xiàn)類。
換句話說,迭代沒有編程語言屬性,但幾乎所有編程語言都支持迭代。
在Java中,無需迭代即可遍歷集合。當然,無需迭代的遍歷僅限于list接口的實現(xiàn)類。因為列表接口指定了可以通過集合索引獲得相應的值,所以無論列表是通過數(shù)組實現(xiàn)還是通過鏈表實現(xiàn)。
但是,Java中的集合不僅是列表,而且是集合。這種非列表集合不能通過索引獲得指定的元素,因此使用迭代方法。
除了list和set之外,Java還有一個雙列集合,也稱為鍵值對集合。但是,這種集合遍歷不能直接迭代。相反,我們使用折衷方法,要么先獲取鍵值集,要么通過遍歷鍵值遍歷映射,要么獲取鍵值集地圖輸入橫穿。
總之,迭代法不屬于任何編程語言,它只是一種設計思想,但大多數(shù)編程語言都會實現(xiàn)它,包括Java。