list迭代器刪除元素 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 Checkforcomodification(){
if(modcount!=expectedmodcount)
throw new concurrent modificationexception()]}
如何刪除一個list中最后一個元素?
要從列表中刪除指定的元素,可以使用remove方法:ArrayList al=newarraylist()al.add公司(“a”)al.add公司(“b”)//al.add公司(“b”)//al.add公司(“c”)//al.add公司(“d”)表示(inti=0i<al.尺寸()i){如果(艾爾蓋特(i) ==“b”{al.移除(i) 在代碼中,刪除元素后,需要將下標減去1。這是因為刪除每個元素后,ArrayList將依次將以下元素上移一個位置(即copy)。因此,下一個要訪問的下標仍然是當前下標,因此必須減去一才能遍歷所有元素。