重載與重寫的區(qū)別 java 刪除list集合為什么要用迭代器?
刪除list集合為什么要用迭代器?當您刪除其中一個時,對應數(shù)組中的元素會清空刪除位置的下標,然后將后續(xù)的數(shù)據(jù)逐個向前推,導致最后一個位置的下標為空。當您到達最后一個位置時,如果沒有數(shù)據(jù),數(shù)組將被報告為
刪除list集合為什么要用迭代器?
當您刪除其中一個時,對應數(shù)組中的元素會清空刪除位置的下標,然后將后續(xù)的數(shù)據(jù)逐個向前推,導致最后一個位置的下標為空。當您到達最后一個位置時,如果沒有數(shù)據(jù),數(shù)組將被報告為越界。迭代器的原理是只有在有下一項時才取值,并且沒有下標,這樣才能保證數(shù)據(jù)的一致性
主要有三種方法:用一個列表記錄要刪除的數(shù)據(jù),最后全部刪除(list);用for循環(huán)遍歷,原始寫入方式;用迭代器的remove方法,這也是官方推薦的方法。
如何遍歷刪除一個list中的特定數(shù)據(jù)?
當您是<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 checkForComodification(){
if(modCount!=expectedModCount)
拋出新的ConcurrentModificationException()
}