Java_List元素的遍历和删除

本文介绍了Java中List的三种常用遍历方法:下标循环、foreach循环和迭代器循环,并对比了它们在ArrayList和LinkedList上的性能表现。

1、创建一个ArrayList

List<Integer> list = new ArrayList<Integer>();

2、List常用的遍历方法有三种:

(1)下标循环

        for (int i = 0, len = list.size(); i < len; i++) {
            System.out.print(list.get(i).toString());
        }

说明:

1)最一般的方法

2)idea快捷键:itar + Tab 或者 fori + Tab

(2)for each循环

        for (Integer elem : list) {
            System.out.print(elem.toString());
        }

说明:在不修改容器长度时,仅仅遍历容器时推荐使用

1)优点:代码简洁美观:不存在索引,所以不用关心下标、初始值、是否越界等

2)缺点:删除容器中的元素容易出错。

3)idea快捷键:iter + Tab 或者 i + Tab

(3)迭代器循环

        for (Iterator iter = list.iterator(); iter.hasNext(); ) {
            System.out.print(iter.next());
        }

或者

        Iterator<Integer> iter = list.iterator();
        while (iter.hasNext()) {
            System.out.print(iter.next());
        }

说明:在删除容器中元素时,最好使用迭代器循环

1)优点:能对容器中的元素进行删除

2)idea快捷键:itco + Tab

3、三种遍历方法的效率比较

见文章:ArrayList和LinkedList的几种循环遍历方式及性能对比分析

这里该文章总结下:

(1)对于ArrayList而言:

1)从速度上看,foreach和迭代器循环速度差不多,但是都比下标遍历慢。

2)综合编码难度,在仅仅对集合进行遍历的时候,只使用for each

(2)对于LinkedList而言:

1)从速度上看,foreach和迭代器循环速度差不多,但是远比下标遍历快。

2)综合编码难度,在仅仅对集合进行遍历的时候,只使用for each

说明:

(1)对于LinkedList,GetAt方法需要一次遍历链表,其时间复杂度为O(n),因此使用下标遍历时,速度很慢,级别为n^2。

(2)对于ArrayList,GetAt方法直接使用下标定位,其时间复杂度为O(1),因此使用下标遍历时,级别为n。


总结:无论对于ArrayList还是LinkedList,

(1)仅对其遍历而不修改容器大小时,只使用foreach循环

(2)需要边遍历边修改容器大小时(插入删除元素),只使用迭代器循环



### Java 中安全遍历 List删除元素的最佳实践 在 Java 中,如果需要在遍历 `List` 的同时删除元素,必须避免直接调用 `List.remove()` 方法,因为这会导致 `ConcurrentModificationException` 异常。最佳实践是使用 `Iterator` 的 `remove()` 方法来安全地删除元素[^2]。 以下是实现方式的详细说明: #### 使用 `Iterator` 删除元素 通过 `Iterator` 遍历集合时,可以调用其 `remove()` 方法来安全地删除当前元素。这种方法不会引发并发修改异常,因为它内部维护了对集合修改状态的跟踪。 ```java import java.util.ArrayList; import java.util.Iterator; import java.util.List; public class SafeRemoveExample { public static void main(String[] args) { List<String> list = new ArrayList<>(); list.add("Java"); list.add("Python"); list.add("C++"); list.add("Go"); Iterator<String> iterator = list.iterator(); while (iterator.hasNext()) { String element = iterator.next(); if ("C++".equals(element)) { iterator.remove(); // 安全删除元素 } } System.out.println(list); // 输出结果:[Java, Python, Go] } } ``` #### 使用 `ListIterator` 删除或修改元素 `ListIterator` 是 `Iterator` 的扩展接口,支持双向遍历以及在遍历时插入、替换或删除元素。与普通 `Iterator` 不同,它提供了更多的灵活性。 ```java import java.util.ArrayList; import java.util.List; import java.util.ListIterator; public class ListIteratorExample { public static void main(String[] args) { List<String> list = new ArrayList<>(); list.add("Java"); list.add("Python"); list.add("C++"); list.add("Go"); ListIterator<String> iterator = list.listIterator(); while (iterator.hasNext()) { String element = iterator.next(); if ("Python".equals(element)) { iterator.set("Ruby"); // 替换元素 } else if ("C++".equals(element)) { iterator.remove(); // 删除元素 } } System.out.println(list); // 输出结果:[Java, Ruby, Go] } } ``` #### 注意事项 1. **禁止直接调用 `List.remove()`**:在遍历过程中直接调用 `list.remove()` 会导致 `ConcurrentModificationException`,因为集合的结构被外部修改而未通知迭代器。 2. **确保调用 `next()` 后再调用 `remove()`**:`Iterator.remove()` 必须在调用 `next()` 至少一次之后才能调用,否则会抛出 `IllegalStateException`。 3. **性能考量**:对于大规模数据集,`Iterator` `ListIterator` 的性能通常优于直接索引操作,尤其是在频繁删除的情况下[^3]。 ### 总结 在 Java 中安全遍历 `List` 并删除元素的最佳实践是使用 `Iterator` 或 `ListIterator` 的 `remove()` 方法。这些方法能够有效避免并发修改异常,同时提供更高的灵活性安全性。 ```java // 示例代码 import java.util.ArrayList; import java.util.Iterator; import java.util.List; public class Main { public static void main(String[] args) { List<String> list = new ArrayList<>(); list.add("A"); list.add("B"); list.add("C"); Iterator<String> it = list.iterator(); while (it.hasNext()) { String item = it.next(); if ("B".equals(item)) { it.remove(); } } System.out.println(list); // 输出结果:[A, C] } } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值