Java集合类ArrayList循环中删除特定元素

Posted 会飞的大鱼

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Java集合类ArrayList循环中删除特定元素相关的知识,希望对你有一定的参考价值。

 

在项目开发中,我们可能往往需要动态的删除ArrayList中的一些元素。


一种错误的方式:

[java] view plain copy
 
  1. for(int i = 0 , len= list.size();i<len;++i){  
  2.   if(list.get(i)==XXX){  
  3.        list.remove(i);  
  4.   }  
  5. }  


上面这种方式会抛出如下异常:

[java] view plain copy
 
  1. Exception in thread "main" java.lang.IndexOutOfBoundsException: Index: 3, Size: 3  
  2.     at java.util.ArrayList.RangeCheck(Unknown Source)  
  3.     at java.util.ArrayList.get(Unknown Source)  
  4.     at ListDemo.main(ListDemo.java:20)  


因为你删除了元素,但是未改变迭代的下标,这样当迭代到最后一个的时候就会抛异常咯。

可以对上面的程序进行如下改进:

[java] view plain copy
 
  1. for(int i = 0 , len= list.size();i<len;++i){  
  2.   if(list.get(i)==XXX){  
  3.        list.remove(i);  
  4.        --len;//减少一个  
  5.        --i;//多谢deny_guoshou指正,如果不加会出现评论1楼所说的情况。  
  6.  }  
  7. }  

上面的代码就正确了。

下面我们再介绍一种方案:

List接口内部实现了Iterator接口,提供开发者一个iterator()得到当前list对象的一个iterator对象。

[java] view plain copy
 
  1. Iterator<String> sListIterator = list.iterator();  
  2. while(sListIterator.hasNext()){  
  3.     String e = sListIterator.next();  
  4.     if(e.equals("3")){  
  5.     sListIterator.remove();  
  6.     }  
  7. }  

上面这种也是正确的,并推荐使用第二种方案。

两种方案实现原理都差多的,第二种只是jdk封装了下。

查看ArrayList源码会发现很多方法内部都是基于iterator接口实现的,所以推荐使用第二种方案。

 


























以上是关于Java集合类ArrayList循环中删除特定元素的主要内容,如果未能解决你的问题,请参考以下文章

Java集合类学习笔记2

Java集合框架 List接口实现类--ArrayList使用 & 删除小明

Java中 ArrayList类常用方法和遍历

Java循环删除集合多个元素的正确打开方式

Java 集合(ListSet)遍历判断删除元素时的小陷阱

用 ArrayList 还是 LinkedList?看完你就懂了!