今天在写代码时要删除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中的多个元素操作就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持小牛知识库。
统计一个一维数组中的各个元素的个数,然后删除多出来的重复元素,并输出结果。 例如:[1,2,2,2,3,3,3,3,3]—>[1,2,3] 解决思路 将重复元素的列表中的重复元素进行统计,并将统计结果放在dictionary中,key为元素,value为该元素的个数 更新此步方法:上述步骤的功能,能够通过另外一个方法实现,即collections.Counter() 然后通过for获取key,得到
问题内容: 我有一堆索引,我想从中删除这些索引中的元素。我无法做一个简单的s 序列,因为每次移除后元素都会移动。我该如何解决? 问题答案: 按降序对索引进行排序,然后将其一一删除。如果这样做,删除将不会影响以后要删除的任何索引。 如何对它们进行排序将取决于您用来存储索引的集合。如果是列表,则可以执行以下操作: 编辑 @aioobe找到了我找不到的助手。除了上述内容,您还可以使用
主要内容:del:根据索引值删除元素,pop():根据索引值删除元素,remove():根据元素值进行删除,clear():删除列表所有元素在 Python 列表中删除元素主要分为以下 3 种场景: 根据目标元素所在位置的索引进行删除,可以使用 del 关键字或者 pop() 方法; 根据元素本身的值进行删除,可使用列表(list类型)提供的 remove() 方法; 将列表中所有元素全部删除,可使用列表(list类型)提供的 clear() 方法。 del:根据索引值删除元素 del 是 Py
lrem key count value 从key对应list中删除count个和value相同的元素。count为0时候删除全部,count为正,则删除匹配count个元素,如果为负数,则是从右侧扫描删除匹配count个元素。复杂度是O(N),N是List长度,因为List的值不唯一,所以要遍历全部元素,而Set只要O(log(N))。 lpop key 从list的头部删除元素,并返回删除元素
本文向大家介绍C#遍历List并删除某个元素的方法,包括了C#遍历List并删除某个元素的方法的使用技巧和注意事项,需要的朋友参考一下 本文实例分析了C#遍历List并删除某个元素的方法。分享给大家供大家参考。具体如下: 1、我们选择用for循环: 如果这样循环,肯定不对, {A B C D E F G H} 假设当前遍历到D(i=3),移除,接着遍历i=4(F), 此时跳过了E(i=3) 2、
问题内容: Python 3.2.5 x64 ElementTree 我有需要使用python格式化的数据。本质上,我具有包含元素和子元素的文件。我需要删除其中一些元素的子元素。我已经检查了先前的问题,但无法解决。到目前为止,我拥有的最好的功能只是删除了每个第二子元素。 样本数据: 我需要的输出看起来像: 我有一段时间没有写任何东西了,我的代码也没用。我可以解析文件,然后将其写入,但我无法正确处理