list迭代器遍歷刪除 刪除list集合為什么要用迭代器?
刪除list集合為什么要用迭代器?當(dāng)您刪除其中一個(gè)時(shí),對(duì)應(yīng)數(shù)組中的元素會(huì)清空刪除位置的下標(biāo),然后將后續(xù)的數(shù)據(jù)逐個(gè)向前推,導(dǎo)致最后一個(gè)位置的下標(biāo)為空。當(dāng)您到達(dá)最后一個(gè)位置時(shí),如果沒(méi)有數(shù)據(jù),數(shù)組將被報(bào)告為
刪除list集合為什么要用迭代器?
當(dāng)您刪除其中一個(gè)時(shí),對(duì)應(yīng)數(shù)組中的元素會(huì)清空刪除位置的下標(biāo),然后將后續(xù)的數(shù)據(jù)逐個(gè)向前推,導(dǎo)致最后一個(gè)位置的下標(biāo)為空。當(dāng)您到達(dá)最后一個(gè)位置時(shí),如果沒(méi)有數(shù)據(jù),數(shù)組將被報(bào)告為越界。迭代器的原理是只有在有下一項(xiàng)時(shí)才取值,并且沒(méi)有下標(biāo),這樣可以保證數(shù)據(jù)的一致性
當(dāng)您是<70時(shí),倒數(shù)第二位,即66,刪除66前列表大小為5,刪除66后列表大小為4,所以不會(huì)拋出異常。第一次遍歷列表大小為5的數(shù)組時(shí),指針66位于index=4中。刪除列表并遍歷大小為4的數(shù)組時(shí),cursor=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)
throw new concurrent modificationexception()]}
java中foreach和迭代器在遍歷List集合,一些情況下為什么能使用集合自動(dòng)的刪除方法刪除元素?
要從列表中刪除指定的元素,可以使用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) 在代碼中,刪除元素后,需要將下標(biāo)減去1。這是因?yàn)閯h除每個(gè)元素后,ArrayList將依次將以下元素上移一個(gè)位置(即copy)。因此,下一個(gè)要訪問(wèn)的下標(biāo)仍然是當(dāng)前下標(biāo),因此必須減去一才能遍歷所有元素。