在我们的一般的代码中,如果想要删除集合里面的几项的话,都是遍历这个这个集合,然后在里面判断一下是不是符合删除的要求,然后进行删除
代码如下:
for(int j=0;j<listString.size();j++) {
if(booleanList.get(j)){
booleanList.remove(j);
listString.remove(j);
System.out.println("删除数据中:index:"+j+"当前集合大小:"+listString.size());
}
}
这样的代码,如果我们这个集合的所有元素都是符号删除条件的,那么这个集合只能删除一半的元素..因为i在自增,而size在变小
如果我们提前获取集合的值得话,待会的操作可能就会越界
真正的实现方法是,在集合的每一次判断删除中,我们如果删除了这个元素,那么我们就把i的值减去1,让他下次依然从这个位置开始算起,到此问题解决
当初想着可麻烦.真正静下心来,其实也是很好解决的,所以遇事一定要淡定
完整代码:
package Test;
import java.util.ArrayList;
public class TestListRemove {
public static void main(String[] args) {
ArrayList<String> listString = new ArrayList<String>();
ArrayList<Boolean> booleanList = new ArrayList<Boolean>();
System.out.println("初始化数据");
for(int i=1;i<5;i++) {
listString.add("this is index:"+i);
//false true false true 删除第2个 第4个
if(i%2==0) {
booleanList.add(true);
} else {
booleanList.add(false);
}
}
System.out.println("删除数据");
for(int j=0;j<listString.size();j++) {
if(booleanList.get(j)){
booleanList.remove(j);
listString.remove(j);
//如果当前的位置上的数据我们需要删除,那么我们就删除,然后记得把游标减一下
//好让他下次依然从这个位置进行删除操作,因为我们此次的删除操作,会导致后面的补过来
j--;
System.out.println("删除数据中:index:"+j+"当前集合大小:"+listString.size());
}
}
//CopyOnWriteArrayList<String> copyOnWriteArrayList = new CopyOnWriteArrayList<String>(listString);
//网上说还有一种利用CopyOnWriteArrayList的方法,这里没有尝试
}
}