使用for循环删除集合元素需要注意的有关问题
使用for循环删除集合元素需要注意的问题
for语句在程序开发中经常被用到,他语法简单逻辑严谨,在一定的情况下可以节省很多用while和dowhile代码量,所以他的应用范围是很广泛的,但是,在应用的时候,如果语句中的自增或者自减变量i若处理不当,就可能给程序带来巨大隐患。例如在用for语句删除集合中的元素时,就可能出现以下的情况。
下面先给个例子大家看一下先。
public class e { public static void main(String[] args) { List<String> tempList = new LinkedList<String>(); tempList.add("A"); tempList.add("B"); tempList.add("C"); for(int i = 0; i < tempList.size(); i++){ tempList.remove(i); } if(tempList.size() > 0){ System.out.println("剩余的个数为:" + tempList.size() + ",具体的元素为:"); for(String t : tempList){ System.out.println(t); } } else{ System.out.println("所有的元素已经删除完毕"); } } }
不知道大家看到问题了没有,或许很多朋友会说,没问题啊。。好吧,下面我们看一下程序的运行结果。
结果竟然出乎我们的意料,竟然还有个B,对吧,为什么呢? 下面就让我们来一起探讨一下吧。
说道这里,首先我们就要先了解一下集合元素删除的内部变化吧,就这个案例来说,
如图,我们分析得到,每当删除一个元素时,集合的size方法的值都会减小1,这将直接导致集合中元素的索引重新排序,进一步说,就是剩余所有元素的索引值都减1,正如上图所示,而for循环语句的局部变量i仍然在递增,这将导致删除操作发生跳跃。从而导致上述B么还有删除的问题。。
下面我们再更改一下程序。
import java.util.LinkedList; import java.util.List; public class test { public static void main(String[] args) { List<String> tempList = new LinkedList<String>(); tempList.add("A"); tempList.add("B"); tempList.add("C"); for(int i = 0; i < tempList.size(); i++){ tempList.remove(i); i--; } if(tempList.size() > 0){ System.out.println("剩余的个数为:" + tempList.size() + ",具体的元素为:"); for(String t : tempList){ System.out.println(t); } } else{ System.out.println("所有的元素已经删除完毕"); } } }
看一下下面的结果, 正确了吧,呵呵。
写下这个的原因是希望大家也注意这些类似的情况,不一定是删除集合时才需要注意。细节不仅能够打败爱情,还能够打败成功,所以要小心哦。。