java定義數(shù)組 刪除list集合為什么要用迭代器?
刪除list集合為什么要用迭代器?當(dāng)您刪除其中一個時,對應(yīng)數(shù)組中的元素會清空刪除位置的下標(biāo),然后將后續(xù)的數(shù)據(jù)逐個向前推,導(dǎo)致最后一個位置的下標(biāo)為空。當(dāng)您到達(dá)最后一個位置時,如果沒有數(shù)據(jù),數(shù)組將被報告為
刪除list集合為什么要用迭代器?
當(dāng)您刪除其中一個時,對應(yīng)數(shù)組中的元素會清空刪除位置的下標(biāo),然后將后續(xù)的數(shù)據(jù)逐個向前推,導(dǎo)致最后一個位置的下標(biāo)為空。當(dāng)您到達(dá)最后一個位置時,如果沒有數(shù)據(jù),數(shù)組將被報告為越界。迭代器的原理是只有在有下一項時才取值,并且沒有下標(biāo),這樣可以保證數(shù)據(jù)的一致性
可以使用clear方法來清除。
1. 使用列表。清除()方法清空集合以釋放內(nèi)存。
2. 如果只是清空集合,可以嘗試創(chuàng)建一個新列表。雖然列表中的元素已不存在,但原始數(shù)據(jù)仍在內(nèi)存中,這是無用的。
java中如何將list集合清空?
1. 刪除public static void removedduplicate(list){for(int i=0 i<)列表大?。ǎ?1 i){對于(int j=列表大?。ǎ?1 j> i j--){如果(列表.獲取(j) .等于(列表.獲?。╥) ){列表.刪除(j) }}}系統(tǒng)輸出打?。斜恚﹠2。通過HashSet HashSet(list)刪除public static void removed duplicate(list){HashSet H=new)列表。清除() 列表.addAll(小時)系統(tǒng)輸出打?。╨ist)}
如何去除List集合中重復(fù)的元素?
ArrayList刪除元素有兩種方法列表.刪除(0), 列表.刪除( 列表大小() - 1) 2 列表.刪除( 列表.獲取(0))刪除第一個元素列表.刪除( 列表.獲取( 列表大?。ǎ?1)刪除最后一個元素
當(dāng)您是<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(){
返回光標(biāo)!=size
}
A< 90,第二位變了,列表的大小也變了
看ArrayList的源代碼,調(diào)用這個方法檢查列表的大小是否每次都變,但是這個方法發(fā)生在hasnext方法之后
1
2
3
4
final void checkForComodification(){
if(modCount!=expectedModCount)
拋出新的ConcurrentModificationException()
}