gpt4 book ai didi

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

转载 作者:行者123 更新时间:2023-12-03 18:11:56 28 4
gpt4 key购买 nike

需要一些关于 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/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com