解决ArrayList.remove()删除元素删不干净的问题

遍历ArrayList时如何正确移除一个元素

在使用ArrayList时遇到个问题,例如

public static void remove(ArrayList<String> list) {
	for (int i = 0; i < list.size(); i++) {
		String s = list.get(i);
		if (s.equals("bb")) {
			list.remove(s);
		}
	}
}

当list中元素像("aa","bb","bb","cc"),待删除元素挨在一起时,用上面的方法删除会出现
image
可以看到"bb"没有被正确地删除。

阅读ArrayList.remove()源码发现

image
image
image

可以看到调用了native方法System.arraycopy,导致删除元素时涉及到数组元素的移动。在
遍历第二个元素字符串bb时因为符合删除条件,所以将该元素从数组中删除,并且将后一个元素移动
(也是字符串bb)至当前位置,导致下一次循环遍历时后一个字符串bb并没有遍历到,所以无法删除。
针对这种情况可以倒序删除的方式来避免:

static void remove2(List<String> list){
        for (int i = list.size()-1;i>=0;i--){
            String s = list.get(i);
            if (s.equals("bb")) {
                list.remove(s);
                System.out.println("删除了bb");
                System.out.println(list.toString());
            }
        }
    }

运行结果如下:
image

posted @ 2022-03-16 20:57  xyha1  阅读(307)  评论(0)    收藏  举报