在我们的一般的代码中,如果想要删除集合里面的几项的话,都是遍历这个这个集合,然后在里面判断一下是不是符合删除的要求,然后进行删除
代码如下:
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的方法,这里没有尝试 } }
时间: 2024-11-09 06:26:36