今天在写代码时要删除List中的多个元素时犯了一个很搞笑的错误,等效的就是以下代码
1
2
3
4
5
6
7
8
9
10
11
12
13
|
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()这个方法又会执行一遍,相当于已经不再是当前的元素了,当时写的还特别顺溜。。。
应该改成下面 这样
1
2
3
4
5
|
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()来删除对象,该方法会在删除当前迭代对象的同时维护索引的一致性。举例:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
|
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中的多个元素操作就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持服务器之家。
原文链接:https://blog.csdn.net/qq_27762917/article/details/78963401