List一边循环一边删除会如何?如何解决?

2024-02-29 16:59
文章标签 解决 删除 循环 list 一边

本文主要是介绍List一边循环一边删除会如何?如何解决?,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

这一个很经典的面试题,相信很多求职者或者新手开发都遇见过。本文主要深究一下为什么list循环删除会抛出异常?如何避免这种情况?

一、增强for循环

package com.bootMybatis.demo;import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;/*** @Author: yd* @Date: 2020/7/18 10:17*/
public class ListDemo {public static void main(String[] args) {List<String> list = new ArrayList<String>();list.add("a");list.add("b");list.add("c");list.add("a");list.add("d");// foreachfor (String str: list) {if ("a".equals(str)) {list.remove(str);}}}
}

运行会抛出:java.util.ConcurrentModificationException 异常具体信息如下:

Exception in thread "main" java.util.ConcurrentModificationExceptionat java.util.ArrayList$Itr.checkForComodification(ArrayList.java:909)at java.util.ArrayList$Itr.next(ArrayList.java:859)at com.bootMybatis.demo.ListDemo.main(ListDemo.java:23)

通过源码分析,我们可以看出来抛出的异常,当获取下一个元素的时候,会先去校验这两个变量是否相等,第一次remove之后,modCount的值由5变成了6,这样就导致了值不相同抛出异常。

二、普通for循环

package com.bootMybatis.demo;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;public class ListDemo {public static void main(String[] args) {List<String> list = new ArrayList<String>();list.add("a");list.add("a");list.add("b");list.add("c");list.add("a");list.add("d");// 普通for循环for (int i = 0; i < list.size();i++){if (list.get(i).equals("a")){list.remove(list.get(i));}}for (String string:list) {System.out.println(string);}}
}

通过这种普通循环删除元素你会发现你要删除的元素存在多个时删除不完,因为删除元素后,数组下标变化了,下一个元素就不会进入比较了。

三、迭代器 用list的remove方法

package com.bootMybatis.demo;import org.hibernate.validator.constraints.EAN;import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;/*** @Author: yd* @Date: 2020/7/18 10:17*/
public class ListDemo {public static void main(String[] args) {List<String> list = new ArrayList<String>();list.add("a");list.add("a");list.add("b");list.add("c");list.add("a");list.add("d");// 迭代器循环Iterator<String> iterator = list.iterator();while(iterator.hasNext()){String str = iterator.next();if ("a".equals(str)){list.remove(str);}}}
}

这种方式会抛出和增强for循环一样的异常,引起的原因相同。

四、迭代器的remove方法

package com.bootMybatis.demo;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;/*** @Author: yd* @Date: 2020/7/18 10:17*/
public class ListDemo {public static void main(String[] args) {List<String> list = new ArrayList<String>();list.add("a");list.add("a");list.add("b");list.add("c");list.add("a");list.add("d");// 迭代器循环Iterator<String> iterator1 = list.iterator();while(iterator1.hasNext()){String str = iterator1.next();if ("a".equals(str)){iterator1.remove();}}}
}

这种方式可以完美解决循环删除的问题。

五、JDK 1.8 的for循环

package com.bootMybatis.demo;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;/*** @Author: yd* @Date: 2020/7/18 10:17*/
public class ListDemo {public static void main(String[] args) {List<String> list = new ArrayList<String>();list.add("a");list.add("a");list.add("b");list.add("c");list.add("a");list.add("d");// JDK 1.8 的循环list.forEach(str -> {if ("a".equals(str)){list.remove(str);}});System.out.println(list.size());}
}

这种方式也会抛出异常:java.util.ConcurrentModificationException ,我们可以通过源码发现还是由于expectedModCount和modCount的值不同导致的异常。

 

这篇关于List一边循环一边删除会如何?如何解决?的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/759420

相关文章

好题——hdu2522(小数问题:求1/n的第一个循环节)

好喜欢这题,第一次做小数问题,一开始真心没思路,然后参考了网上的一些资料。 知识点***********************************无限不循环小数即无理数,不能写作两整数之比*****************************(一开始没想到,小学没学好) 此题1/n肯定是一个有限循环小数,了解这些后就能做此题了。 按照除法的机制,用一个函数表示出来就可以了,代码如下

电脑桌面文件删除了怎么找回来?别急,快速恢复攻略在此

在日常使用电脑的过程中,我们经常会遇到这样的情况:一不小心,桌面上的某个重要文件被删除了。这时,大多数人可能会感到惊慌失措,不知所措。 其实,不必过于担心,因为有很多方法可以帮助我们找回被删除的桌面文件。下面,就让我们一起来了解一下这些恢复桌面文件的方法吧。 一、使用撤销操作 如果我们刚刚删除了桌面上的文件,并且还没有进行其他操作,那么可以尝试使用撤销操作来恢复文件。在键盘上同时按下“C

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

如何解决线上平台抽佣高 线下门店客流少的痛点!

目前,许多传统零售店铺正遭遇客源下降的难题。尽管广告推广能带来一定的客流,但其费用昂贵。鉴于此,众多零售商纷纷选择加入像美团、饿了么和抖音这样的大型在线平台,但这些平台的高佣金率导致了利润的大幅缩水。在这样的市场环境下,商家之间的合作网络逐渐成为一种有效的解决方案,通过资源和客户基础的共享,实现共同的利益增长。 以最近在上海兴起的一个跨行业合作平台为例,该平台融合了环保消费积分系统,在短

pip-tools:打造可重复、可控的 Python 开发环境,解决依赖关系,让代码更稳定

在 Python 开发中,管理依赖关系是一项繁琐且容易出错的任务。手动更新依赖版本、处理冲突、确保一致性等等,都可能让开发者感到头疼。而 pip-tools 为开发者提供了一套稳定可靠的解决方案。 什么是 pip-tools? pip-tools 是一组命令行工具,旨在简化 Python 依赖关系的管理,确保项目环境的稳定性和可重复性。它主要包含两个核心工具:pip-compile 和 pip

【VUE】跨域问题的概念,以及解决方法。

目录 1.跨域概念 2.解决方法 2.1 配置网络请求代理 2.2 使用@CrossOrigin 注解 2.3 通过配置文件实现跨域 2.4 添加 CorsWebFilter 来解决跨域问题 1.跨域概念 跨域问题是由于浏览器实施了同源策略,该策略要求请求的域名、协议和端口必须与提供资源的服务相同。如果不相同,则需要服务器显式地允许这种跨域请求。一般在springbo

poj3750约瑟夫环,循环队列

Description 有N个小孩围成一圈,给他们从1开始依次编号,现指定从第W个开始报数,报到第S个时,该小孩出列,然后从下一个小孩开始报数,仍是报到S个出列,如此重复下去,直到所有的小孩都出列(总人数不足S个时将循环报数),求小孩出列的顺序。 Input 第一行输入小孩的人数N(N<=64) 接下来每行输入一个小孩的名字(人名不超过15个字符) 最后一行输入W,S (W < N),用

Collection List Set Map的区别和联系

Collection List Set Map的区别和联系 这些都代表了Java中的集合,这里主要从其元素是否有序,是否可重复来进行区别记忆,以便恰当地使用,当然还存在同步方面的差异,见上一篇相关文章。 有序否 允许元素重复否 Collection 否 是 List 是 是 Set AbstractSet 否

速盾高防cdn是怎么解决网站攻击的?

速盾高防CDN是一种基于云计算技术的网络安全解决方案,可以有效地保护网站免受各种网络攻击的威胁。它通过在全球多个节点部署服务器,将网站内容缓存到这些服务器上,并通过智能路由技术将用户的请求引导到最近的服务器上,以提供更快的访问速度和更好的网络性能。 速盾高防CDN主要采用以下几种方式来解决网站攻击: 分布式拒绝服务攻击(DDoS)防护:DDoS攻击是一种常见的网络攻击手段,攻击者通过向目标网

Jenkins 插件 地址证书报错问题解决思路

问题提示摘要: SunCertPathBuilderException: unable to find valid certification path to requested target...... 网上很多的解决方式是更新站点的地址,我这里修改了一个日本的地址(清华镜像也好),其实发现是解决不了上述的报错问题的,其实,最终拉去插件的时候,会提示证书的问题,几经周折找到了其中一遍博文