当前位置 : 主页 > 编程语言 > java >

使用Iterator删除List中的多个元素操作

来源:互联网 收集:自由互联 发布时间:2021-04-10
今天在写代码时要删除List中的多个元素时犯了一个很搞笑的错误,等效的就是以下代码 public static void main(String[] args) { ListString a = new ArrayListString(); a.add("1"); a.add("2"); a.add("3"); a.add("4"

今天在写代码时要删除List中的多个元素时犯了一个很搞笑的错误,等效的就是以下代码

  public static void main(String[] args) {
    List<String> a = new ArrayList<String>();
    a.add("1");
    a.add("2");
    a.add("3");
    a.add("4");
    a.add("5");
    Iterator<String> iterator = a.iterator();
    while(iterator.hasNext()){
      if("1".equals(iterator.next()) || "2".equals(iterator.next()))
        iterator.remove();
    }
  }

运行后发现只能删除“1”这个元素,“2”删除不掉,后来才发现判断的时候如果第一个条件不满足,iterator.next()这个方法又会执行一遍,相当于已经不再是当前的元素了,当时写的还特别顺溜。。。

应该改成下面 这样

while(iterator.hasNext()){
  String str = iterator.next();
  if("1".equals(str) || "2".equals(str))
    iterator.remove();
}

把当前指向的元素单独提出来放在条件判断里面,平时在写普通循环的时候写习惯了,没有把循环中的元素提出来。

记录一下

补充知识:Iterator遍历集合时不可以删除集合中的元素问题

博客用于记录编程是遇到的问题,便于以后随时复习。

Iterator是工作在一个独立的线程中,拥有一个mutex锁。Iterator被创建后会建立一个指向原来对象的单链索引表,当原来的对象数量发生变化时,这个索引表的内容不会同步改变,所以当索引指针向后面移动的时候就找不到要迭代的对象,按照fail-fast原则,Iterator会马上抛出 java.util.ConcurrentModificationException异常。

所以,在Iterator工作时,不允许迭代对象被改变。但可以使用Iterator本身的方法iterator.remove()来删除对象,该方法会在删除当前迭代对象的同时维护索引的一致性。举例:

import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
public class TestIterator {
public void iteratorDelete(List<Integer>list){
Iterator<Integer> it=list.iterator();
while(it.hasNext()){
Integer integer=it.next();
if (integer<20) {
//可以删除
it.remove();
//运行时异常
// list.remove(integer);
}
}
System.out.println(list.toString());
}
public static void main(String[] args) {
List<Integer>list=new ArrayList<>();
list.add(18);
list.add(20);
list.add(30);
list.add(40);
TestIterator testIterator=new TestIterator();
testIterator.iteratorDelete(list);
}
}

以上这篇使用Iterator删除List中的多个元素操作就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持易盾网络。

网友评论