边循环边删除List中的数据

List边循环,边删除;这种一听感觉就像是会出问题一样,其实只要是删除特定数据,就不会出问题,你如果直接循环删除所有数据,那可能就会出问题了,比如:

    public static void main(String[] args) {List<String> list = new ArrayList<>();list.add("1");list.add("2");list.add("3");list.add("4");for (int i=0;i<list.size();i++){list.remove(i);}System.out.println(list);}

结果:

[2, 4]

删除的所有,但是最终还留下两个值,这是因为当一个元素被移除时,该List的大小(size)就会缩减,同时也改变了索引的指向,也就是上面的代码只会循环两次,长度在不断减少,第一次循环0 < 4 ,第二次循环 1 < 3 ,不满足下一次循环条件 2 < 2,故只有两次循环就结束。所以,在迭代的过程中使用索引,将无法从List中正确地删除多个指定的元素。

当使用了foreach 如下:

    public static void main(String[] args) {List<String> list = new ArrayList<>();list.add("1");list.add("2");list.add("3");list.add("4");for (String i:list){list.remove(i);}System.out.println(list);}

结果直接报错:

Exception in thread "main" java.util.ConcurrentModificationExceptionat java.util.ArrayList$Itr.checkForComodification(ArrayList.java:901)at java.util.ArrayList$Itr.next(ArrayList.java:851)at com.gwh.demo.test.ListTest.main(ListTest.java:18)

这是因为,在 foreach循环中,编译器使得 remove()方法先于next()方法被调用,因为先执行了remove()方法,导致next()获取的数组长度和remove()后的数组长度不一致,则抛出异常。
在这里插入图片描述
如果使用了Iterator 迭代器模式,如下:

    public static void main(String[] args) {List<String> list = new ArrayList<>();list.add("1");list.add("2");list.add("3");list.add("4");Iterator<String> iterator = list.iterator();while (iterator.hasNext()){// 必须先执行一下next() 否则会抛出异常iterator.next();iterator.remove();}System.out.println(list);}

这样保证next()先执行一下,这样删除所有就不会出问题了。

如果是循环List,同时删除符合要求的数据,则不管使用那种方式都不会出现问题。demo代码如下:

for循环:

    public static void main(String[] args) {HashMap<String, Object> map = new HashMap<String, Object>();map.put("id",1);map.put("name","张三");map.put("sex","男");map.put("age",18);HashMap<String, Object> map1 = new HashMap<String, Object>();map1.put("id",2);map1.put("name","李四");map1.put("sex","男");map1.put("age",18);HashMap<String, Object> map2 = new HashMap<String, Object>();map2.put("id",3);map2.put("name","王五");map2.put("sex","男");map2.put("age",18);HashMap<String, Object> map3 = new HashMap<String, Object>();map3.put("id",4);map3.put("name","赵六");map3.put("sex","男");map3.put("age",18);List<HashMap<String,Object>> list = new ArrayList<HashMap<String,Object>>();list.add(map);list.add(map1);list.add(map2);list.add(map3);for(int i=0;i<list.size();i++){if(Integer.valueOf(String.valueOf(list.get(i).get("id")))== 1){list.remove(i);}}System.out.println(list);}

结果如下:

[{sex=男, name=李四, id=2, age=18}, {sex=男, name=王五, id=3, age=18}, {sex=男, name=赵六, id=4, age=18}]

迭代器如下:

    public static void main(String[] args) {HashMap<String, Object> map = new HashMap<String, Object>();map.put("id",1);map.put("name","张三");map.put("sex","男");map.put("age",18);HashMap<String, Object> map1 = new HashMap<String, Object>();map1.put("id",2);map1.put("name","李四");map1.put("sex","男");map1.put("age",18);HashMap<String, Object> map2 = new HashMap<String, Object>();map2.put("id",3);map2.put("name","王五");map2.put("sex","男");map2.put("age",18);HashMap<String, Object> map3 = new HashMap<String, Object>();map3.put("id",4);map3.put("name","赵六");map3.put("sex","男");map3.put("age",18);List<HashMap<String,Object>> list = new ArrayList<HashMap<String,Object>>();list.add(map);list.add(map1);list.add(map2);list.add(map3);Iterator<HashMap<String, Object>> iterator = list.iterator();while (iterator.hasNext()){HashMap<String, Object> next = iterator.next();if(Integer.valueOf(String.valueOf(next.get("id")))== 1){iterator.remove();}}System.out.println(list);}

结果:

[{sex=男, name=李四, id=2, age=18}, {sex=男, name=王五, id=3, age=18}, {sex=男, name=赵六, id=4, age=18}]

还可以使用 JDK8特性stream 流过滤:

public static void main(String[] args) {HashMap<String, Object> map = new HashMap<String, Object>();map.put("id",1);map.put("name","张三");map.put("sex","男");map.put("age",18);HashMap<String, Object> map1 = new HashMap<String, Object>();map1.put("id",2);map1.put("name","李四");map1.put("sex","男");map1.put("age",18);HashMap<String, Object> map2 = new HashMap<String, Object>();map2.put("id",3);map2.put("name","王五");map2.put("sex","男");map2.put("age",18);HashMap<String, Object> map3 = new HashMap<String, Object>();map3.put("id",4);map3.put("name","赵六");map3.put("sex","男");map3.put("age",18);List<HashMap<String,Object>> list = new ArrayList<HashMap<String,Object>>();list.add(map);list.add(map1);list.add(map2);list.add(map3);List<HashMap<String, Object>> co = list.stream().filter(p -> Integer.valueOf(String.valueOf(p.get("id"))) != 1).collect(Collectors.toList());System.out.println(co);}

结果:

[{sex=男, name=李四, id=2, age=18}, {sex=男, name=王五, id=3, age=18}, {sex=男, name=赵六, id=4, age=18}]

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/661723.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

上位机图像处理和嵌入式模块部署(树莓派4b与mcu固件升级)

【 声明&#xff1a;版权所有&#xff0c;欢迎转载&#xff0c;请勿用于商业用途。 联系信箱&#xff1a;feixiaoxing 163.com】 在一个系统当中&#xff0c;可能不止需要树莓派4b一个设备。有的时候还需要搭载一个mcu&#xff0c;做一些运动控制的事情。比如说&#xff0c;图像…

第七篇:专家级指南:Python异常处理的艺术与策略

专家级指南&#xff1a;Python异常处理的艺术与策略 1 引言 在编程的世界中&#xff0c;异常处理是一门必修的艺术。它不仅涉及到程序的错误处理&#xff0c;更广泛地影响着软件的稳定性、健壮性和用户体验。本篇文章将深入探讨Python中的异常处理&#xff0c;展示如何通过精心…

【专篇】DDR4 SDRAM-01总体介绍

概念 DDR4 SDRAM(Double-Data-Rate Fourth Generation Synchronous Dynamic Random Access Memory)是一种先进的高性能存储器规格,是DDR3 SDRAM的后续产品。自2011年首次由三星电子制造并公布以来,它已经成为现代计算机系统中广泛采用的内存标准。 主要特点: 更高带宽: DD…

【C语言】——数据在内存中的存储

【C语言】——数据在内存中的存储 一、整数在内存中的存储1.1、整数的存储方式1.2、大小端字节序&#xff08;1&#xff09;大小端字节序的定义&#xff08;2&#xff09;判断大小端 1.3、整型练习 二、浮点数在内存中的存储2.1、引言2.2、浮点数的存储规则2.3、浮点数的存储过…

[附源码]SpringBoot+Vue网盘项目_仿某度盘

视频演示 [附源码]SpringBootVue网盘项目_仿某度盘 功能介绍 支持秒传支持视频音频播放、拖拽进度条、倍速播放等支持图片预览&#xff0c;旋转&#xff0c;放大支持多人一起上传&#xff0c;共享上传进度&#xff08;例如a上传苍老师学习资料到50%&#xff0c;突然b也上传苍老…

Android项目中添加Dobby(inline hook)

2024技术交流群 ​ 课程地址 鸿蒙(HarmonyOS)APP开发实战课程(入门到精通) https://edu.csdn.net/course/detail/39448 1.Ubuntu编译Dobby 2.Dobby框架的介绍 Dobby是一个轻量级、多平台、多架构的inline hook框架&#xff0c;它使用起来轻快便捷&#xff0c;支持Windows/ma…

配置及使用OpenCV(Python)

python配置OpenCV相对于c的配置方法容易的多&#xff0c;但建议在Anaconda中的Python虚拟环境中使用&#xff0c;这样更方便进行包管理和环境管理&#xff1a; 先激活Anaconda的python虚拟环境&#xff1a; conda activate GGBoy 随后下载 opencv 包&#xff1a; conda ins…

C语言字符串(0基础到深入剖析)---字符串系列合集(函数+指针+数组)

前言 本篇旨在帮助不了解字符串或者逻辑梳理不够透彻的伙伴们理出一条脉络。选择能看懂的部分即可&#xff0c;建议收藏&#xff0c;后期学习完C语言方便回顾。 适用范围&#xff1a;0基础C语言&#xff08;刚学字符串&#xff09;- 学过函数 - 学过指针 ---大致了解了数据内…

Linux 第十七章

&#x1f436;博主主页&#xff1a;ᰔᩚ. 一怀明月ꦿ ❤️‍&#x1f525;专栏系列&#xff1a;线性代数&#xff0c;C初学者入门训练&#xff0c;题解C&#xff0c;C的使用文章&#xff0c;「初学」C&#xff0c;linux &#x1f525;座右铭&#xff1a;“不要等到什么都没有了…

SQLite Expert安装与注册

SQLite Expert安装与注册 下载安装 下载安装 下载对应的位数的SQLite Expert&#xff1a;http://www.sqliteexpert.com/download.html &#xff0c;建议下载professional版本的&#xff0c;功能更加强大。 如果官网进不去可以到百度云下载&#xff1a; https://pan.baidu.com…

【UnityRPG游戏制作】Unity_RPG项目之场景环境搭建和解析

&#x1f468;‍&#x1f4bb;个人主页&#xff1a;元宇宙-秩沅 &#x1f468;‍&#x1f4bb; hallo 欢迎 点赞&#x1f44d; 收藏⭐ 留言&#x1f4dd; 加关注✅! &#x1f468;‍&#x1f4bb; 本文由 秩沅 原创 &#x1f468;‍&#x1f4bb; 收录于专栏&#xff1a;Uni…

MATLAB - 机器人动力学 - 质心(Center of Mass)

系列文章目录 前言 一、用法 com centerOfMass(robot) com centerOfMass(robot,configuration) [com,comJac] centerOfMass(robot,configuration) 二、说明 com centerOfMass(robot) 计算机器人模型在原点构型处相对于基础坐标系的质心位置。com centerOfMass(robot,conf…