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

标签 java list memory-leaks

需要一些关于 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());

    }

但是当我运行这段代码时它给出了异常

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)

还有一个要注意的是 enter image description here

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

enter image description here

问题是 为什么给出 IndexOutOfBoundsException ?

那个 modCoutn 是什么?

这是否会成为内存泄漏的原因,如果是,如何解决?

提前致谢。

最佳答案

从列表中删除元素会使列表变小。您的第二个循环运行到 10000,但是当它到达那里时列表将缩减到不到 10000。

事实上,如果您的意图是删除所有 50 的倍数,您可以从 10000 向后循环到 0,步长为 50 并避免这个问题,并且速度更快。

for (int i=9950; i>=0; i-=50){
    lst.remove(i);
}

请注意,如果您的意图是删除 50 的倍数,您当前的方法将不起作用,因为在第一次删除每个索引处的值是索引的不变量之后,不再成立。

modCount 是一个内部变量,ArrayList 使用它来检测它是否参照其上的任何 Iterators 而改变。它基本上计算了对列表的所有修改。迭代器保留自己的计数,并检查它是否与列表保持同步。

您的代码不会导致任何内存泄漏。在 Java 内存“泄漏”中,如果不再使用的对象仍然被引用,因此它们不能被垃圾收集。但是由于示例中的所有内容都在方法范围之外传递,所以一旦离开方法,所有内容都可以被 gc。 (因为它是 main 方法,vm 将停止运行并释放其内存)

关于java - 需要一些关于 java.util.list 的说明,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13814595/

相关文章:

java - eclipse 不让我创建动态 Web 项目

java - 开发Android应用程序时使用外部库

使用 getString 进行 Java clob 检索 - 字符编码问题

list - 在 while_loop TensorFlow 函数内索引列表

c++ - 在 C++ 中有没有什么方法可以防止内存泄漏而不要求开发人员额外注意它

java - Android 上的两个级别的 Activity 。无缝过渡

python - 从字符串数组列表中获取值?

python - 如何在多个字典中只保留全局最大值的键值对?

Python argparse 出现在 gc.garbage 中

c# - Windows Phone 8.1 WinRT 内存泄漏与 ObservableCollection