List remove造成循环结果异常

博客主要讲述Java中List移除元素的问题。List移除元素后后面元素会前移,若执行i=i+1,刚移过来的元素会被跳过。给出三种解决方法,即倒序遍历list、移除元素后将i移回、使用iterator.remove()方法删除。
public static void main(String[] args) {
        String str1 = new String("abcde");
        String str2 = new String("abcde");
        String str3 = new String("abcde");
        String str4 = new String("abcde");
        String str5 = new String("abcde");
        List<String> list = new ArrayList<>();

        list.add(str1);
        list.add(str2);
        list.add(str3);
        list.add(str4);
        list.add(str5);

        System.out.println("list.size()=" + list.size());
        for (int i = 0; i < list.size(); i++) {
            if (((String) list.get(i)).startsWith("abcde")) {
                list.remove(i);
            }
        }
        System.out.println("after remove:list.size()=" + list.size());
    }

结果:

原因:

List每remove掉一个元素以后,后面的元素都会向前移动,此时如果执行i=i+1,则刚刚移过来的元素没有被读取

 解决方法:

1、倒过来遍历list

for (int i = list.size()-1; i > =0; i--) {
  if (((String) list.get(i)).startsWith("abcde")) {
   list.remove(i);
  }
}

2、每移除一个元素以后再把i移回来

for (int i = 0; i < list.size(); i++) {
  if (((String) list.get(i)).startsWith("abcde")) {
   list.remove(i);
   i=i-1;
  }
}

3、使用iterator.remove()方法删除

if (null != list && list.size() > 0) {
    Iterator it = list.iterator();  
    while(it.hasNext()){
        Student stu = (Student)it.next(); 
        if (stu.getStudentId() == studentId) {
            it.remove(); //移除该对象
        }
    }
}

### 在for循环中对List进行remove操作的异常行为及解决方案 在Java和Python等编程语言中,直接在`for`循环中对列表(如Java中的`ArrayList`或Python中的`list`)进行`remove`操作可能会引发异常或导致未预期的行为。以下是详细分析及其解决方案。 #### Java中的异常行为 在Java中,如果使用增强型`for`循环(即`for (Entity node : list)`)对`ArrayList`进行`remove`操作,会抛出`java.util.ConcurrentModificationException`[^2]。这是因为增强型`for`循环内部使用了迭代器(Iterator),而当通过非迭代器方法(如`list.remove()`)修改集合时,迭代器检测到结构被修改后会抛出此异常。 为避免这种异常,可以改用带索引的`for`循环,并在删除元素后调整索引值以防止跳过后续元素: ```java for (int i = 0; i < list.size(); i++) { Entity node = list.get(i); list.remove(i); i -= 1; // 调整索引以确保正确遍历 } ``` #### Python中的异常行为 在Python中,直接在`for`循环中对`list`进行`remove`操作不会抛出异常,但会导致某些元素未被遍历。这是因为`remove`操作改变了列表的长度和索引位置,从而影响了循环的正常执行[^3]。 例如,以下代码会导致部分元素未被删除: ```python for item in my_list: if condition(item): my_list.remove(item) ``` 为了正确处理这种情况,可以采用以下两种常见解决方案: 1. **倒序遍历**:从列表末尾向前遍历,这样即使删除元素也不会影响前面元素的索引。 ```python for i in range(len(my_list) - 1, -1, -1): if condition(my_list[i]): my_list.pop(i) ``` 2. **创建副本**:在循环中遍历原始列表的副本,同时对原列表进行修改。 ```python for item in my_list[:]: # 使用切片创建副本 if condition(item): my_list.remove(item) ``` #### 注意事项 - 在Java中,推荐使用`Iterator`的`remove`方法来安全地删除元素,因为它能与迭代器同步工作[^1]。 - 在Python中,避免直接修改正在遍历的列表,除非采取适当的措施(如倒序遍历或使用副本)。 - 如果需要删除多个相同的元素,应确保`equals`方法(Java)或`__eq__`方法(Python)正确实现,以便准确比较元素内容[^1]。 ### 示例代码 #### Java示例 ```java import java.util.ArrayList; public class Main { public static void main(String[] args) { ArrayList<String> list = new ArrayList<>(); list.add("A"); list.add("B"); list.add("C"); for (int i = 0; i < list.size(); ) { if ("B".equals(list.get(i))) { list.remove(i); } else { i++; } } System.out.println(list); // 输出: [A, C] } } ``` #### Python示例 ```python my_list = ["A", "B", "C", "B"] # 方法1:倒序遍历 for i in range(len(my_list) - 1, -1, -1): if my_list[i] == "B": my_list.pop(i) print(my_list) # 输出: ['A', 'C'] # 方法2:创建副本 my_list = ["A", "B", "C", "B"] for item in my_list[:]: if item == "B": my_list.remove(item) print(my_list) # 输出: ['A', 'C'] ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

睡竹

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值