NoN*_*aMe 2 java memory-leaks list
需要一些澄清java.util.list.我正在使用eclipse进行开发.
我写了这段代码
public static void main(String[] asdf){
List<Integer> lst = new ArrayList<Integer>();
for(int i=0;i<10000;i++){
lst.add(i);
}
System.out.println(lst.size());
for(int i=0;i<10000;i++){
if((i%50)==0){
lst.remove(i);
}
}
System.out.println(lst.size());
}
Run Code Online (Sandbox Code Playgroud)
但是,当我运行此代码时,它会给出异常
Exception in thread "main" java.lang.IndexOutOfBoundsException: Index: 9850, Size: 9803
at java.util.ArrayList.rangeCheck(ArrayList.java:604)
at java.util.ArrayList.remove(ArrayList.java:445)
at com.ilex.reports.action.rpt.CNSReports.main(CNSReports.java:301)
Run Code Online (Sandbox Code Playgroud)
还有一个需要注意的是

然后我做了一个代码更改,即迭代第二循环,直到5000只,它工作正常

问题是 为什么要给IndexOutOfBoundsException?
什么是modCoutn?
这件事有没有成为记忆泄漏的理由如果是,如何解决呢?
提前致谢.
bow*_*ore 16
从列表中删除元素会使其变小.你的第二个循环运行到10000,但是当它到达那里时,列表将缩小到小于10000.
事实上,如果你的目的是删除50的所有倍数,你可以从10000向后循环到0,步长为50并避免这个问题,并且更快.
for (int i=9950; i>=0; i-=50){
lst.remove(i);
}
Run Code Online (Sandbox Code Playgroud)
请注意,如果您的目的是删除50的倍数,那么您当前的方法将无效,因为在第一次删除不变量后,每个索引处的值都是索引,不再成立.
modCount是一个内部变量,ArrayList用它来检测它是否在引用任何迭代器时被更改.它基本上计算对List的所有修改.迭代器保留自己的计数,并检查它是否与List保持同步.
您的代码不会导致任何内存泄漏.在java内存'泄漏'中,如果仍然引用不再使用的对象,则不能对它们进行垃圾回收.但是由于示例中的所有内容都超出了方法的范围,因此一旦离开方法,所有内容都可以被gc'd.(因为它是主要方法,vm将停止运行并释放其内存)