ArrayList遍歷的同時刪除--- 刪除還是用迭代器的比較好,其它的都會有問題.


http://javag.iteye.com/blog/403097

 

ArrayList遍歷的同時刪除--

刪除還是用迭代器的比較好,其它的都會有問題.

 

 
 
博客分類:

方法一

Java代碼   收藏代碼
  1. ArrayList<String> list = new ArrayList<String>();  
  2.         list.add("one");  
  3.         list.add("two");  
  4.         list.add("two");  
  5.         list.add("two");  
  6.         list.add("two");  
  7.         for(int i=0;i<list.size();i++){  
  8.             if(list.get(i).equals("two")){  
  9.                 list.remove(i);  
  10.             }  
  11.         }  
  12.         System.out.println(list);  

 結果:

Java代碼   收藏代碼
  1. [one, two, two]  

 方法二

Java代碼   收藏代碼
  1. ArrayList<String> list = new ArrayList<String>();  
  2. list.add("one");  
  3. list.add("two");  
  4. list.add("two");  
  5. list.add("two");  
  6. list.add("two");  
  7. for(String s:list){  
  8.     if(s.equals("two")){  
  9.         list.remove(s);  
  10.     }  
  11. }  
  12. System.out.println(list);  

 

結果:

Java代碼   收藏代碼
  1. Exception in thread "main" java.util.ConcurrentModificationException  
  2.     at java.util.AbstractList$Itr.checkForComodification(AbstractList.java:372)  
  3.     at java.util.AbstractList$Itr.next(AbstractList.java:343)  
  4.     at Test.main(Test.java:22)  

 

方法三:

Java代碼   收藏代碼
  1. ArrayList<String> list = new ArrayList<String>();  
  2. list.add("one");  
  3. list.add("two");  
  4. list.add("two");  
  5. list.add("two");  
  6. list.add("two");  
  7. Iterator<String> iter = list.iterator();  
  8. while(iter.hasNext()){  
  9.     String s = iter.next();  
  10.     if(s.equals("two")){  
  11.         iter.remove();  
  12.     }  
  13. }  
  14. System.out.println(list);  

結果:

Java代碼   收藏代碼
  1. [one]  

 

結論:

刪除還是用迭代器的比較好,其它的都會有問題.


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM