java迭代器是什么 java中foreach和迭代器在遍歷List集合,一些情況下為什么能使用集合自動的刪除方法刪除元素?
java中foreach和迭代器在遍歷List集合,一些情況下為什么能使用集合自動的刪除方法刪除元素?你a<70的時候是倒數(shù)第二位,也就是66,沒有拋出異常是因為之前l(fā)ist大小為5,你刪除66后
java中foreach和迭代器在遍歷List集合,一些情況下為什么能使用集合自動的刪除方法刪除元素?
你a<70的時候是倒數(shù)第二位,也就是66,沒有拋出異常是因為之前l(fā)ist大小為5,你刪除66后,list大小為4,你第一次遍歷list大小為5的數(shù)組的時候,66的cursor在index = 4,當你刪除后,遍歷list大小為4的數(shù)組時, cursor = 4 = newlist.size()。
ArrayList里的這個方法就會判斷l(xiāng)ist已經(jīng)讀取完畢了,所以不會拋出異常。
1
2
3
public boolean hasNext() {
return cursor != size
}
a < 90的時候在第二位就發(fā)生了變化,list的大小也發(fā)生了變化
看了下ArrayList的源碼,每次循環(huán)的時候都會call這個方法檢查list的大小是否發(fā)生了變化,但是這個方法是發(fā)生在hasNext方法之后的
1
2
3
4
final void checkForComodification() {
if (modCount != expectedModCount)
throw new ConcurrentModificationException()
}
在java中集合中迭代是怎么一回事兒?為什么要進行集合的迭代?
其實嚴格來說,迭代是一種設計模式,迭代的目的是遍歷某一類數(shù)據(jù)集合的內容,而無需了解該類數(shù)據(jù)的數(shù)據(jù)結構。
其實現(xiàn)思路是:定義一個迭代器接口,該接口至少聲明兩個方法,分別是:hasNext(),和next()。通過hasNext()判斷是否還有可遍歷元素,通過next()返回可遍歷元素。至于具體實現(xiàn)則根據(jù)不同需求創(chuàng)建不同實現(xiàn)類即可。
也就是說,迭代本沒有編程語言屬性,只不過幾乎所有的編程語言都會支持迭代罷了。
在Java中遍歷集合可以不用迭代方式,當然,不用迭代方式的遍歷僅限于List接口的實現(xiàn)類。因為List接口規(guī)定可以通過集合索引來取得對應的值,不論這個List用的是數(shù)組還是鏈表實現(xiàn)。
但是,Java中的集合不僅僅只有List,還有Set。像這種非List集合是無法通過索引來獲取指定元素的,所以這時候迭代方式就排上了用場。
除了List和Set之外,Java還有一種雙列集合,又稱key-value鍵值對集合。只不過這種集合遍歷時無法直接通過迭代方式遍歷。而是通過折中方式,要么先獲得key值集合,通過遍歷key來遍歷map,要么是獲得Map.Entry的集合來遍歷。
總之,迭代方式不屬于任何編程語言,它只是一種設計思想,只不過大多數(shù)編程語言會去實現(xiàn)它罷了,包括Java。
迭代器主要作用是什么?
你好,很高興能為您解答。
迭代器在其實就是指針,讀取集合或者數(shù)組中的一個值,讀完以后又指向下一條數(shù)據(jù)。
迭代器是很好用的一個東西,以java為例,在遍歷list或者map等對象的時候,效率比較高,而且能實現(xiàn)一些for循環(huán)不能實現(xiàn)的功能。例如remove。
希望我的回答對你有所幫助
對于一個java程序員來說,深入了解迭代器的概念重要嗎?
首先來普及一下迭代器概念。迭代器(iterator)有時又稱游標(cursor)是程序設計的軟件設計模式,可在容器(container,例如鏈表或陣列)上遍訪的接口,設計人員無需關心容器的內容。java迭代器 較多使用在容器中,如數(shù)組鏈表 。
作為一種設計模式,迭代器可以用于遍歷一個對象,對于這個對象的底層結構開發(fā)人員不必去了解。迭代器的使用也十分簡單?,F(xiàn)在簡要的總結下使用迭代 器的好處吧。
1、迭代器可以提供統(tǒng)一的迭代方式。
2、迭代器也可以在對客戶端透明的情況下,提供各種不同的迭代方式。
3、迭代器提供一種快速失敗機制,防止多線程下迭代的不安全操作。
由于Java中數(shù)據(jù)容器眾多,而對數(shù)據(jù)容器的操作在很多時候都具有極大的共性,于是Java采用了迭代器為各種容器提供公共的操作接口。使用Java的迭代器iterator可以使得對容器的遍歷操作完全與其底層相隔離,可以到達極好的解耦效果。
但是迭代的次數(shù)取決于集合的元素數(shù)量,在刪除或增加集合中的元素的時候,迭代的次數(shù)會發(fā)生變化,而向集合的非末尾的位置插入元素導致的結果會更致命,會導致先前迭代出的元素又一次訪問到,或者有的元素訪問不到。