在使用for循环判断删除元素,遇到了一些坑,为了突出效果特地将for循环与迭代进行比较。code
List<String> list = new ArrayList<>(); list.add("a"); list.add("a"); list.add("b"); list.add("n"); for (int i = 0; i < list.size(); i++) { if("a".equals(list.get(i))){ list.remove(i); } } List<String> list2 = new ArrayList<>(); list2.add("a"); list2.add("a"); list2.add("b"); list2.add("n"); Iterator<String> iterator = list2.iterator(); while(iterator.hasNext()){ if("a".equals(iterator.next())){ iterator.remove(); } } System.out.println("使用for循环删除后的结果:"+list); System.out.println("使用迭代删除后的结果:"+list2);
使用for循环删除后的结果:[a, b, n] 使用迭代删除后的结果:[b, n]
由于for循环删除,每删除一个元素,索引就会发生改变,若是两个符合条件的元素靠近一块儿的话。 就会致使只会删除一个元素的状况出现,所以,删除集合元素时建议使用迭代器删除