JAVA 循环删除list中元素的方法总结
摘要:介绍List集合实现元素边遍历边删除的方法,例如removeIf和迭代器iterator.remove()等。
综述
List集合是我们开发中经常使用到的一种集合形式,有时候会遇到在遍历List集合时需要删除指定的元素。但在根据条件使用for循环或者增强的for循环遍历删除某些元素时却不能随心所欲地使用remove函数,我们今天便从实现层面讨论下原因以及Iterator的相关知识。伸手党或者资深大佬看完下面的总结就行,不必阅读全文。
比如,有一个字符串类型的List,包含四个元素:“软件”、“del”、“开发”、“领路人”,我们要实现的是在遍历这个集合时,删除长度为2的字符串元素。要怎么做呢?有如下几种方法:
- for循环倒序删除
- iterator遍历删除
- 使用removeIf删除
for循环倒序删除
顺序删除时,会报错,提示:Exception in thread "main" java.util.ConcurrentModificationException:
for(int i=0;i < list.size();i++){
if(list.get(i).equals("del"))
list.remove(i);
}
这种方式的问题在于,删除某个元素后,list的大小发生了变化,而数组下标也在变化,所以会导致在遍历的时候漏掉某些元素。比如删除第1个元素后,继续根据角标访问第2个元素时,因为删除的关系后面的元素都往前移动了一位,所以实际访问的是第3个元素。因此,这种方式可以用在删除特定的一个元素后就终止循环时使用,尤其不适合循环删除多个元素时使用。
结论:for循环正序删除的问题在于,删除某个元素后,其后元素的数组下标将向前挪一位,所以会导致在遍历的时候漏掉被删除元素的后一个元素。解决办法:从list最后一个元素开始从后向前遍历。
/**
* 倒序删除:删除list集合中属性全为null的对象
*
*/
private void removeEmptyObjectInList(List<? extends Object> list) {
if (null != list && list.size() > 0) {
for (int i = list.size() - 1; i >= 0; i--) {
if(list.get(i) == null){
list.remove(i);
}
}
}
}
public static void main(String[] args) {
List<String> list = new LinkedList<String>();
list.add("a");
list.add("b");
list.add("c");
list.add("d");
list.add("e");
for(int i=0;i<list.size();i++){
System.out.println("即将删除的元素:"+list.get(i));
list.remove(i);
i--;
}
}
当要针对角标进行元素的remove时,使用倒序遍历的方式最为妥当。
使用foreach删除
使用增强型for循环 foreach 删除指定元素:
for(String x:list){
if(x.equals("del")){
System.out.println("即将删除的元素:"+x);
list.remove(x);
}
}
这种方式的问题在于,删除元素后继续循环会抛异常ConcurrentModificationException,因为元素在使用的时候发生了并发修改,导致异常被抛出。但是删除完毕马上使用break跳出,则不会触发报错。
iterator遍历删除
下面提供一个用迭代器在遍历List集合时删除元素的方法:
Iterator it = list.iterator();
while(it.hasNext()){
String x = it.next();
if(x.equals("del")){
System.out.println("即将删除的元素:"+x);
it.remove();
}
}
能达到预期效果吗?我们执行后验证一下就知道了。在控制台可以看到如下结果,说明已经被删除:
即将删除的元素:del
这种方式可以正常的循环及删除。但要注意的是,调用iterator的remove方法时,如果用list的remove方法同样会报上面提到的ConcurrentModificationException错误。
使用removeIf删除
在 Java 8 中,Collection及其子类新加入了removeIf函数,作用是按照特定规则过滤集合中的元素。语法为:
arraylist.removeIf(Predicate<E> filter)
参数说明:filter - 过滤器,判断元素是否被删除,如果元素被删除则filter返回 true。实例,删除等于del的元素:
list.removeIf(s-> s.equals("del"));
结束语
总结:
(1)删除list中某一个元素时,可以使用上述几种方式中的任意一种。
(2)循环删除list中多个元素时,应该使用for循环倒序删除、迭代器iterator或者removeIf。
以上就是小编分享给各位程序猿的全部内容了,希望各位读后有所收获,也希望大家多多支持楼兰胡杨。
JAVA 循环删除list中元素的方法总结的更多相关文章
- JAVA中循环删除list中元素的方法总结【转】
印象中循环删除list中的元素使用for循环的方式是有问题的,但是可以使用增强的for循环,然后今天在使用时发现报错了,然后去科普了一下,再然后发现这是一个误区.下面就来讲一讲..伸手党可直接跳至文末 ...
- java中循环删除list中元素的方法
重点哈 印象中循环删除list中的元素使用for循环的方式是有问题的,但是可以使用增强的for循环,然后今天在使用时发现报错了,然后去科普了一下,再然后发现这是一个误区.下面就来讲一讲..伸手党可直接 ...
- JS实现循环删除数组中元素的方法介绍
这篇文章主要给大家介绍了关于Javascript循环删除数组中元素的几种方法,文中给出了详细的示例代码供大家参考学习,对大家具有一定的参考学习价值,需要的朋友们下面来一起看看吧. 本文主要跟大家分享了 ...
- Java中循环删除list中元素的方法总结
印象中循环删除list中的元素使用for循环的方式是有问题的,但是可以使用增强的for循环,然后在今天使用的时候发现报错了,然后去科普了一下,发现这是一个误区.下面我们来一起看一下. Java中循环遍 ...
- JAVA中循环删除list中元素的方法总结(同上篇)
印象中循环删除list中的元素使用for循环的方式是有问题的,但是可以使用增强的for循环,然后今天在使用时发现报错了,然后去科普了一下,再然后发现这是一个误区.下面就来讲一讲..伸手党可直接跳至文末 ...
- python中循环删除列表中元素时的坑!
循环删除列表中元素时千万别用正序遍历,一定要用反序遍历! 废话不多说,先上案例代码: def test(data): for i in data: data.remove(i) return data ...
- JAVA中循环删除list中元素
文章来源: https://www.cnblogs.com/pcheng/p/5336903.html JAVA中循环遍历list有三种方式for循环.增强for循环(也就是常说的foreach循环) ...
- js删除数组中元素的方法
一.清空数组 var ary = [1,2,3,4]; ary.splice(0,ary.length);//清空数组 console.log(ary); // 输出 [],空数组,即被清空了 二.删 ...
- python删除列表中元素的方法
删除列表中元素的三种方法-remove.pop.del 1 1.remove: 删除单个元素,删除首个符合条件的元素,按值删除 2 举例说明: 3 >>> str=[1,2,3,4, ...
- Javascript循环删除数组中元素的几种方法示例
发现问题 大家在码代码的过程中,经常会遇到在循环中移除指定元素的需求.按照常规的思路,直接一个for循环,然后在循环里面来个if判断,在判断中删除掉指定元素即可.但是实际情况往往不会像预想的那样顺利运 ...
随机推荐
- git安装教程以及生成git ssh key
问题 GitHub拉取代码需要SSH,总是忘记命令,现网百度.记录下来,以后靠自己的博文 第一步 安装git 地址: https://git-scm.com/download/win 安装它 第二步 ...
- 【Matlab】判断点和多面体位置关系的两种方法实现
分别是向量判别法(算法来自他人论文).体积判别法(code 是我从网上找的). 方法一: 向量判别法 方法来自一会议论文:<判断点与多面体空间位置关系的一个新算法_石露>2008年,知网. ...
- 6. MySQL 索引的数据结构(详细说明)
6. MySQL 索引的数据结构(详细说明) @ 目录 6. MySQL 索引的数据结构(详细说明) 1. 为什么使用索引 2. 索引及其优缺点 2.1 索引概述 3. InnoDB中索引的推演 3. ...
- selenium 提示消息一闪而过,怎么定位
F12 点击source 下的暂停按钮
- 移动端 cordova vue videojs 全屏播放后退出全屏返回后退出app问题
问题描述 移动端上面使用了videojs 播放视频,同时也监听了手机返回事件document.addEventListener('backbutton',.接着我们点击全屏播放后在退出全屏在返回后直接 ...
- Golang 入门 : 常量
常量 相对于变量而言,常量是在程序使用过程中,不会改变的数据.有些地方你需要将定义好的常量重复使用,代码中你不允许它的值改变.例如 圆周率 在程序执行过程中不会改变. 常量的声明 const Pi f ...
- 漫画赏析:Linux 内核到底长啥样
今天,我来为大家解读一幅来自 TurnOff.us 的漫画 "InSide The Linux Kernel" . TurnOff.us 是一个极客漫画网站,作者Daniel St ...
- Docker Hub 镜像加速器——持续更新(2025年3月12日)
国内从 Docker Hub 拉取镜像有时会遇到困难,此时可以配置镜像加速器.Docker 官方和国内很多云服务商都提供了国内加速器服务. 配置加速地址 Ubuntu 16.04+.Debian 8+ ...
- 渗透技巧——CDN绕过
渗透技巧--CDN绕过 一.前言: 在渗透站点的时候常常会遇见站点有CDN加速情况,就无法准确的找到目标IP.首先是检测如何发现有无CDN,然后才能说绕过的问题. 二.检测有无CDN: 首先有以下几种 ...
- 0x03 搜索与图论
搜索与图论 广度优先搜索\(BFS\) 概念 广度优先搜索(Breadth-First Search)是一种图遍历算法,用于在图或树中按层次逐层访问节点.它从源节点(起始节点)开始,首先访问源节点的所 ...