溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

JAVA遍歷List集合,刪除數(shù)據(jù)時出現(xiàn)問題怎么辦

發(fā)布時間:2020-07-16 13:42:03 來源:億速云 閱讀:176 作者:小豬 欄目:開發(fā)技術(shù)

小編這次要給大家分享的是JAVA遍歷List集合,刪除數(shù)據(jù)時出現(xiàn)問題怎么辦,文章內(nèi)容豐富,感興趣的小伙伴可以來了解一下,希望大家閱讀完這篇文章之后能夠有所收獲。

一、問題描述

有時候,我們會遇到在遍歷List集合的過程中刪除數(shù)據(jù)的情況。

看著自己寫的代碼,感覺完全沒有問題,但就是達不到預期的效果,這是為什么呢?下面我們來分析下

String str1 = new String("1"); 
String str2 = new String("2"); 
String str3 = new String("3"); 
String str4 = new String("4"); 
String str5 = new String("5"); 
List list = new ArrayList(); 
list.add(str1); 
list.add(str2); 
list.add(str3); 
list.add(str4); 
list.add(str5); 
System.out.println("list.size()=" + list.size());     
 
for (int i = 0; i < list.size(); i++) {        
    list.remove(i);      
  // i--; 
  //System.out.println(i+" "+list.get(i)+" "); 
}     
System.out.println("after remove:list.size()=" + list.size());

本來預期結(jié)果應該是:

list.size()=5 
after remove:list.size()=0 

但實際上結(jié)果卻是:

list.size()=5 
after remove:list.size()=2

原因如下: List每remove掉一個元素以后,后面的元素都會向前移動 ,此時如果執(zhí)行i++,則剛剛移過來的元素沒有被讀取。

分析:

  • List中有5條數(shù)據(jù),需要循環(huán)5次,
  • 第一次數(shù)據(jù)為:1 2 3 4 5
  • 執(zhí)行完remove(0) 后,數(shù)據(jù)為 2 3 4 5  , i=1
  • 第二次數(shù)據(jù)為:2 3 4 5
  • 執(zhí)行完remove(1) 后,數(shù)據(jù)為 2 4 5  , i=2
  • 第三次數(shù)據(jù)為:2 4 5
  • 執(zhí)行完remove(2) 后,數(shù)據(jù)為 2 4  , i=3
  • 此時如果加上上面注釋的代碼 System.out.println(i+" "+list.get(i)+" "); 循環(huán)第4、5次時就會出現(xiàn)異常
     

二、解決方法

解決方法1:每移過一次后,再把 i 移回來

for (int i = 0; i < list.size(); i++) {        
  list.remove(i);      
  i--;       
}

解決方法2:先刪除后面的元素

for (int i = list.size()-1; i >= 0; i--) { list.remove(i); }

解決方法3:使用iterator刪除

for(Iterator it = list.iterator();it.hasNext();){       
  it.remove(); 
}

看完這篇關(guān)于JAVA遍歷List集合,刪除數(shù)據(jù)時出現(xiàn)問題怎么辦的文章,如果覺得文章內(nèi)容寫得不錯的話,可以把它分享出去給更多人看到。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI