我有个奇怪的问题。我以为这会花费我几分钟的时间,但我现在已经挣扎了几个小时……下面是我得到的信息:
for (int i = 0; i < size; i++){
if (data.get(i).getCaption().contains("_Hardi")){
data.remove(i);
}
}data是ArrayList中的ArrayList.,我得到了一些字符串(总共14个左右),其中有9个字符串的名字是_Hardi。
使用上面的代码,我想删除它们。如果我用System.out.println replace data.remove(i);,那么它会打印9次,什么是好的,因为_Hardi在ArrayList中9次。
但是当我使用data.remove(i);时,它不会删除所有的9个,而是只删除了几个。我做了一些测试,我还看到了这个:
当我将字符串重命名为: Hardi1 Hardi2 Hardi3 Hardi4 Hardi5 Hardi6时
然后,它只删除开偶数(1、3、5等)。他总是跳过1,但不知道为什么。
如何解决这个问题?或者是另一种删除它们的方法?
发布于 2012-05-24 21:48:31
这里的问题是,您正在从0到迭代大小,并且在循环中您正在删除项。删除项目将减小列表的大小,当您尝试访问大于有效大小(已删除项目之后的大小)的索引时,列表将失败。
有两种方法可以做到这一点。
如果不想处理索引,请使用迭代器删除。
for (Iterator<Object> it = data.iterator(); it.hasNext();) {
if (it.next().getCaption().contains("_Hardi")) {
it.remove();
}
}否则,从末尾删除。
for (int i = size-1; i >= 0; i--){
if (data.get(i).getCaption().contains("_Hardi")){
data.remove(i);
}
}发布于 2012-05-24 21:41:23
在遍历列表时,不应该删除列表中的项。相反,请使用Iterator.remove(),如下所示:
for (Iterator<Object> it = list.iterator(); it.hasNext();) {
if ( condition is true ) {
it.remove();
}
}发布于 2013-06-11 19:56:43
这是因为当您从列表中删除一个元素时,该列表的元素会向上移动。因此,如果您删除索引为0的第一个元素ie,则索引为1的元素将被移至索引0,但循环计数器将在每次迭代中不断增加。所以你得到的不是第0个index元素,而是第1个index元素。因此,每次从列表中删除一个元素时,只需将计数器减1即可。
您可以使用以下代码使其正常工作:
for (int i = 0; i < data.size(); i++){
if (data.get(i).getCaption().contains("_Hardi")){
data.remove(i);
i--;
}
}https://stackoverflow.com/questions/10738634
复制相似问题