需要一些关于java.util.list的说明

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将停止运行并释放其内存)