iterator迭代器用法 java中foreach和迭代器在遍歷List集合,一些情況下為什么能使用集合自動(dòng)的刪除方法刪除元素?
java中foreach和迭代器在遍歷List集合,一些情況下為什么能使用集合自動(dòng)的刪除方法刪除元素?當(dāng)您是<70時(shí),倒數(shù)第二位是66。您沒(méi)有引發(fā)異常,因?yàn)橐郧暗牧斜泶笮∈?。刪除66后,列表大小
java中foreach和迭代器在遍歷List集合,一些情況下為什么能使用集合自動(dòng)的刪除方法刪除元素?
當(dāng)您是<70時(shí),倒數(shù)第二位是66。您沒(méi)有引發(fā)異常,因?yàn)橐郧暗牧斜泶笮∈?。刪除66后,列表大小為4。第一次遍歷列表大小為5的數(shù)組時(shí),指針66位于index=4中。遍歷列表大小為4的數(shù)組時(shí),指針66位于index=4中newlist.size文件()。
ArrayList中的此方法將判斷列表已被讀取,因此不會(huì)引發(fā)異常。
1]]2
3
公共布爾hasnext(){
返回光標(biāo)!=size
}
A< 90,第二位變了,列表的大小也變了
看ArrayList的源代碼,調(diào)用這個(gè)方法檢查列表的大小是否每次都變,但是這個(gè)方法發(fā)生在hasnext方法之后
1
2
3
4
final void checkForComodification(){
if(modCount!=expectedModCount)
拋出新的Concurrentmodificationexception()
}
刪除list集合為什么要用迭代器?
遍歷常用方法時(shí),將使用數(shù)組下標(biāo)。刪除其中一個(gè)元素時(shí),刪除位置的下標(biāo)對(duì)于相應(yīng)數(shù)組中的元素將為空,隨后的數(shù)據(jù)將向前推送,導(dǎo)致最后一個(gè)位置的下標(biāo)為空。當(dāng)你轉(zhuǎn)到最后一個(gè),它將沒(méi)有數(shù)據(jù),然后它將被刪除它的界限。迭代器的原理是只有在有下一項(xiàng)時(shí)才取值,沒(méi)有下標(biāo),這樣可以保證數(shù)據(jù)的一致性