在Java中,List的remove(i)方法用于删除指定索引位置的元素。但是,如果在使用remove(i)方法时,不是按照索引的顺序依次删除元素,而是跳过某些元素,那么可能会导致结果不正确。 例如,如果我们有一个List,其中包含元素[A, B, C, D, E],然后我们想要删除索引为1、3、4的元素,如果我们按照以下方式执行remove(i)方法: list.remove(1); list.remove(3); list.remove(3); 那么最终的结果将会是[A, C, E],而不是我们期望的[A, C]。
这是因为,当我们执行list.remove(1)时,元素B被删除,索引3和4向前移动了一位,此时索引3对应的元素变成了E。然后我们执行list.remove(3),此时索引3对应的元素是E,而不是我们期望的D。因此,最终结果中包含了元素E。
为了避免这种问题,我们可以按照索引的顺序依次删除元素,或者使用Iterator来删除元素。代码如下:
List<String> list = new ArrayList<>(Arrays.asList("A", "B", "C", "D", "E"));
Iterator<String> iterator = list.iterator();
while (iterator.hasNext()) {
String element = iterator.next();
if (element.equals("B") || element.equals("D") || element.equals("E")) {
iterator.remove();
}
}
System.out.println(list); // Output: [A, C]
在上面的示例中,我们首先创建了一个包含元素[A, B, C, D, E]的ArrayList。然后,我们使用list.iterator()方法获取Iterator对象,使用while循环遍历List中的元素。在每次循环中,我们使用iterator.next()方法获取下一个元素,如果该元素需要被删除,我们就使用iterator.remove()方法将其从List中删除。最后,我们输出List中剩余的元素,结果为[A, C]。使用Iterator来删除元素可以避免使用remove(i)方法时的索引错位问题。