Java面试题篇·(大神分享总结)List如何一边遍历,一边删除?

platformList.remove(platform);

modCount的值就被修改成了4。


所以在第2次获取元素时,modCount和expectedModCount的值就不相等了,所以抛出了java.util.ConcurrentModificationException异常。

既然不能使用foreach来实现,那么我们该如何实现呢?
主要有以下3种方法:

使用Iterator的remove()方法
使用for循环正序遍历
使用for循环倒序遍历

接下来一一讲解。
#2. 使用Iterator的remove()方法
使用Iterator的remove()方法的实现方式如下所示:

public static void main(String[] args) {
List platformList = new ArrayList<>();
platformList.add(“博客园”);
platformList.add(“CSDN”);
platformList.add(“掘金”);

Iterator iterator = platformList.iterator();
while (iterator.hasNext()) {
String platform = iterator.next();
if (platform.equals(“博客园”)) {
iterator.remove();
}
}

System.out.println(platformList);
}

输出结果为:
[CSDN, 掘金]
为什么使用iterator.remove();就可以呢?

让我们看下它的源码:

可以看出,每次删除一个元素,都会将modCount的值重新赋值给expectedModCount,这样2个变量就相等了,不会触发java.util.ConcurrentModificationException异常。
#3. 使用for循环正序遍历
使用for循环正序遍历的实现方式如下所示:

public static void main(String[] args) {
List platformList = new ArrayList<>();
platformList.add(“博客园”);
platformList.add(“CSDN”);
platformList.add(“掘金”);

for (int i = 0; i < platformList.size(); i++) {
String item = platformList.get(i);

if (item.equals(“博客园”)) {
platformList.remove(i);
i = i - 1;
}
}

System.out.println(platformList);
}

这种实现方式比较好理解,就是通过数组的下标来删除,不过有个注意事项就是删除元素后,要修正下下标的值:

i = i - 1;

为什么要修正下标的值呢?

因为刚开始元素的下标是这样的:

第1次循环将元素"博客园"删除后,元素的下标变成了下面这样:

第2次循环时i的值为1,也就是取到了元素”掘金“,这样就导致元素"CSDN"被跳过检查了,所以删除完元素后,我们要修正下下标,这也是上面代码中i = i - 1;的用途。
#4. 使用for循环倒序遍历
使用for循环倒序遍历的实现方式如下所示:

public static void main(String[] args) {
List platformList = new ArrayList<>();
platformList.add(“博客园”);
platformList.add(“CSDN”);
platformList.add(“掘金”);

for (int i = platformList.size() - 1; i >= 0; i–) {
String item = platformList.get(i);

if (item.equals(“掘金”)) {
platformList.remove(i);
}
}

System.out.println(platformList);
}

这种实现方式和使用for循环正序遍历类似,不过不用再修正下标,因为刚开始元素的下标是这样的:

第1次循环将元素"掘金"删除后,元素的下标变成了下面这样:

第2次循环时i的值为1,也就是取到了元素”CSDN“,不会导致跳过元素,所以不需要修正下标。
#5. 评论区释疑(2020-06-15更新)
5.1 使用removeIf()方法(推荐)
从JDK1.8开始,可以使用removeIf()方法来代替 Iterator的remove()方法实现一边遍历一边删除,其实,IDEA中也会提示:

所以原来的代码:

Iterator iterator = platformList.iterator();
while (iterator.hasNext()) {
String platform = iterator.next();
if (platform.equals(“博客园”)) {
iterator.remove();
}
}

就可以简化为如下所示的1行代码,非常简洁:

platformList.removeIf(platform -> “博客园”.equals(platform));

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注Java获取)

img

总结:心得体会

既然选择这个行业,选择了做一个程序员,也就明白只有不断学习,积累实战经验才有资格往上走,拿高薪,为自己,为父母,为以后的家能有一定的经济保障。

学习时间都是自己挤出来的,短时间或许很难看到效果,一旦坚持下来了,必然会有所改变。不如好好想想自己为什么想进入这个行业,给自己内心一个答案。

面试大厂,最重要的就是夯实的基础,不然面试官随便一问你就凉了;其次会问一些技术原理,还会看你对知识掌握的广度,最重要的还是你的思路,这是面试官比较看重的。

最后,上面这些大厂面试真题都是非常好的学习资料,通过这些面试真题能够看看自己对技术知识掌握的大概情况,从而能够给自己定一个学习方向。包括上面分享到的学习指南,你都可以从学习指南里理顺学习路线,避免低效学习。

大厂Java架构核心笔记(适合中高级程序员阅读):

《一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码》点击传送门即可获取!
阅读):**

[外链图片转存中…(img-BHmKbrN8-1712162592174)]

《一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码》点击传送门即可获取!

  • 15
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值