第一种方式,基本原理是,每次list删除元素后,后面的元素都要往前移动一位,就相当于i多加了1,remove后继续遍历就会错过一个元素,所以就需要代码中的i--,抵消remove后,后面元素前移一位的影响
for (int i = 0; i < list.size(); i++) {
if(list.get(i).equals("a")){
list.remove(list.get(i));
i--;
}
}
第二种方式,按索引从大到小,这样remove方法的删除元素导致的后面的元素往前移动一位,对遍历就没有影响了。
for(int i = list.size()-1;i>-1;i--) {
if(list.get(i).equals("a")){
list.remove(list.get(i));
}
}
第三种方式,基本思想和第一种相似,不同的是,是用iterator对象,内含两个指针cursor和lastRet实现的,如果调用remove,相当于cursor回退了一位,和第一种的i--思想有些像。
Iterator<String> iterator = list.iterator();
while (iterator.hasNext()) {
String s = iterator.next();
if("a".equals(s)) {
iterator.remove();
}
}
本文详细介绍了在Java中从List中删除元素的三种有效方法。第一种是在遍历过程中使用索引并调整迭代器,第二种是从后向前遍历并直接删除,第三种是利用Iterator的remove方法。每种方法都有其适用场景,理解这些技巧对于优化代码效率至关重要。
3410

被折叠的 条评论
为什么被折叠?



