摘要:通过进行遍历删除符合条件的多个元素使用的方式也可以顺利删除和遍历这里要使用的方法移除当前对象,如果使用的方法,则同样会出现
1.通过增强的for循环删除符合条件的多个元素
/** * 使用增强的for循环 * 在循环过程中从List中删除元素以后,继续循环List时会报ConcurrentModificationException */ public void listRemove() { List2.通过增强的for循环删除符合条件的一个元素students = this.getStudents(); for (Student stu : students) { if (stu.getId() == 2) students.remove(stu); } }
/** * 像这种使用增强的for循环对List进行遍历删除,但删除之后马上就跳出的也不会出现异常 */ public void listRemoveBreak() { List3.通过普通的for删除删除符合条件的多个元素students = this.getStudents(); for (Student stu : students) { if (stu.getId() == 2) { students.remove(stu); break; } } }
/** * 这种遍历有可能会遗漏某个元素,因为删除元素后List的size在 * 变化,元素的索引也在变化,比如你循环到第2个元素的时候你把它删了, * 接下来你去访问第3个元素,实际上访问到的是原先的第4个元素。当访问的元素 * 索引超过了当前的List的size后还会出现数组越界的异常,当然这里不会出现这种异常, * 因为这里每遍历一次都重新拿了一次当前List的size。 */ public void listRemove2() { Liststudents = this.getStudents(); for (int i=0; i 4.通过Iterator进行遍历删除符合条件的多个元素
/** * 使用Iterator的方式也可以顺利删除和遍历 */ public void iteratorRemove() { Liststudents = this.getStudents(); System.out.println(students); Iterator stuIter = students.iterator(); while (stuIter.hasNext()) { Student student = stuIter.next(); if (student.getId() % 2 == 0) //这里要使用Iterator的remove方法移除当前对象,如果使用List的remove方法,则同样会出现ConcurrentModificationException stuIter.remove(); } System.out.println(students); }
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/68289.html
摘要:删除元素后,立即跳出,则正常退出,但不能向后继续循环了删除后立马终端循环,会正常跳出,但代价是不能继续向后循环了使用迭代器使用迭代器可,正确无误的删除,代码简洁优雅,推荐使用使用迭代器可,正确无误的删除注意这里时而不是 在工作中的许多场景下,我们都会使用到List这个数据结构,那么同样的有很多场景下需要删除List中的某一个元素或某几个元素,那么我们该如何正确无误地删除List中的元素...
摘要:与稀疏数组对立的为密集数组,密集数组的索引会被持续的创建,并且其元素的数量等于其长度。创建一个长度为的数组,并初始化了个元素使用构造函数创建数组对象的时候,关键字是可以省略的。另外使用和删除元素是影响数组的长度的。 说明:本文只总结了JavaScript数组在web端的行为,不包括NodeJs端的行为。本文不涉及类型化数组(TypedArray)的讨论、总结。 一、什么是数组 数组的定...
摘要:原因是用发起任何形式的遍历时,它的遍历顺序都是从最初就确定的,而在遍历中删除了元素会导致当前索引的变化,这样一是会导致漏删元素,二是会导致遍历超过链表的长度。所以遍历一个时要删除其中的部分元素就需要其他的解决方案。 Python的for可以遍历一个List,但是在遍历的过程中删除元素常常会得到意想不到的结果甚至程序出现异常,例如: lst = [1, 1, 0, 2, 0, 0, 8,...
摘要:允许从任一方向来遍历对象,并在遍历迭代过程中进行修改该对象,还能获得迭代器的当前位置。这个构造函数是将返回了一个对象给,这也是的存储实现原理。 一、容器产生的原因 1.数组的缺点:大小一旦给定就无法更改,除非复制到一个新的数组中,开销大;而容器类都可以自动地调整自己的尺寸。 2.容器功能的多样性:容器可以实现各种不同要求,如按不同依据将元素进行排序或者保证容器内无重复元素等等。关...
阅读 1824·2023-04-25 14:49
阅读 3099·2021-09-30 09:47
阅读 3072·2021-09-06 15:00
阅读 2206·2019-08-30 13:16
阅读 1419·2019-08-30 10:48
阅读 2651·2019-08-29 15:11
阅读 1257·2019-08-26 14:06
阅读 1648·2019-08-26 13:30