为什么java中迭代过程中不能加元素
有这样的情况:
List<Integer> list = new ArrayList<Integer>();
list.add(0);
Iterator<Integer> iterator = list.iterator();
while(iterator.hasNext()) {
int i = iterator.next();
if(i = 0) {
list.add(1);
list.remove(0);
}
}
...
此时系统编译执行会抛出异常!!!为什么呢?
百度网友(Irreappearable
http://zhidao.baidu.com/question/395975852.html)答:
逻辑上讲,迭代时可以添加元素,但是一旦开放这个功能,很有可能造成很多意想不到的情况。
比如你在迭代一个ArrayList,迭代器的工作方式是依次返回给你第0个元素,第1个元素,等等,假设当你迭代到第5个元素的时候,你突然在ArrayList的头部插入了一个元素,使得你所有的元素都往后移动,于是你当前访问的第5个元素就会被重复访问。
java认为在迭代过程中,容器应当保持不变。因此,java容器中通常保留了一个域称为modCount,每次你对容器修改,这个值就会加1。当你调用iterator方法时,返回的迭代器会记住当前的modCount,随后迭代过程中会检查这个值,一旦发现这个值发生变化,就说明你对容器做了修改,就会抛异常。
分析透彻,说得很好。
另可以参考这里:
http://blog.sina.com.cn/s/blog_60cc33d70100omhm.html
针对这个问题,这里我提出两个解决方案:
1. 另再新建一个列表B,复制原列表的内容,然后就可以在原列表迭代的时候,操作这个新建的拷贝列表B
2. 可以不用Iterator迭代器,采用for循环来遍历列表,如:
import java.util.ArrayList;
import java.util.List;
public class TestListIterator {
public static void main(String[] args) {
// TODO Auto-generated method stub
List<Integer> list = new ArrayList<Integer>();
list.add(0);
for(int i=0; i<list.size() && i<5 ; i++) {
list.add(i+1);
}
System.out.println(list);
}
}
分享到:
相关推荐
Java中的`Iterator`接口是Java集合框架的重要组成部分,它提供了遍历集合元素的机制。`Iterator`被设计用来遍历各种类型的集合,如ArrayList、LinkedList、Set等。在这个主题中,我们将深入理解`Iterator`的工作原理...
迭代器模式是一种行为设计模式,它允许我们顺序访问聚合对象的元素,而无需暴露其底层表示。...同时,由于迭代器接口的存在,我们可以在不修改聚合类的情况下增加新的遍历策略。这就是迭代器模式的核心价值所在。
迭代器模式是设计模式中的一种行为模式,它提供了一种顺序访问聚合对象中各个元素的方法,而又不暴露其内部表示。在Java中,迭代器模式的实现主要依赖于`java.util.Iterator`接口和`java.util.ArrayList`、`java....
通过迭代器,我们可以方便地遍历集合,添加、删除或修改元素,同时保持了集合的封装性。 1. **迭代器接口** Java中的`Iterator`接口位于`java.util`包下,它是所有迭代器的基类。它提供了三个核心方法: - `...
* 在遍历过程中,不能修改集合或数组的内容,以免引发ConcurrentModificationException异常。 * 使用迭代器的remove方法来删除当前迭代对象,而不是使用集合的remove方法。 通过了解增强for循环的实现原理和可能...
- 如果试图在迭代过程中添加元素,会导致`UnsupportedOperationException`异常。这是因为`Iterator`的设计初衷是为了避免在遍历过程中修改集合,从而提高程序的稳定性。 #### 三、Enhanced for loop:现代的迭代...
当我们需要遍历`HashMap`中的所有元素时,通常会使用`Iterator`接口,它是Java集合框架的一部分,提供了对集合的迭代访问。 `Iterator`接口定义了三个基本方法:`hasNext()`、`next()`和`remove()`。`hasNext()`...
Java的迭代器中的fast-...在Java中,迭代器(Iterator)被设计用来遍历和修改集合,当一个线程正在使用迭代器遍历集合时,如果另一个线程修改了集合的内容(添加、删除或修改元素),就会触发fast-fail机制,从而抛出`...
首先,了解为什么在`forEach`循环中不能直接修改集合是很重要的。Java集合框架中的`forEach`循环是基于迭代器的`hasNext()`和`next()`方法实现的。在迭代过程中,如果检测到集合的结构发生了变化(即被修改了),...
在Java、C#等面向对象语言中,迭代器模式被广泛应用于容器类,如ArrayList、LinkedList等,使得我们可以遍历集合中的每一个元素。 迭代器模式包含以下主要角色: 1. **迭代器接口(Iterator)**:定义了遍历集合...
2. 无法在循环中添加或删除元素,除非你有原始集合的引用并使用非迭代器方法。这可能导致`ConcurrentModificationException`,就像在使用迭代器时一样。 以下是一个使用`for-each`循环的例子,遍历一个`ArrayList`...
- **增加了聚合类的灵活性**,添加新类型的元素或改变遍历顺序时,不需要修改原有代码。 在"迭代器模式demo"中,你可以看到如何创建和使用迭代器来遍历一个自定义的聚合对象。这将帮助你理解如何在实际项目中应用...
迭代器模式(IteratorPattern)是设计模式中的一种行为模式,它提供了一种顺序访问聚合对象元素的方法,同时又不暴露其底层表示。这种模式允许我们遍历集合对象的元素,而无需暴露其内部结构。在Java、C#等面向对象...
然而,迭代器模式也存在一些局限性,比如无法对不在聚合内的元素进行操作,且如果聚合类和迭代器有深度耦合,修改其中一方可能会影响到另一方。 在实际开发中,我们经常结合其他设计模式一起使用迭代器,例如工厂...
for-each循环会自动处理迭代过程,遍历ArrayList中的所有元素。 总结来说,两种迭代方法各有优缺点。`Iterator`提供了更灵活的控制,例如在遍历时删除元素,而增强型for循环则提供了简洁的语法,适合简单的遍历操作...
在迭代器遍历过程中,对集合进行修改(如添加或删除元素)可能会影响迭代器的行为。例如,如果在调用`next()`之后调用`remove()`,则通常不会有问题。但是,在调用`hasNext()`或`next()`之前删除元素可能会导致...
当你在一个迭代器正在遍历集合的过程中添加或删除元素时,就会抛出这个异常。这个问题在单线程环境下不会出现,但在多线程并发场景下,如果多个线程同时修改一个集合,就可能导致`ConcurrentModificationException`...
在Java编程中,`ListIterator`是`List`接口提供的一种特殊的迭代器,它具有双向遍历的能力,不仅可以向前遍历列表,还可以向后遍历。`ListIterator`还提供了在遍历过程中添加、修改和删除元素的功能,使得对列表的...
而内置迭代器(Iterator)是Java集合框架的重要组成部分,用于遍历集合中的元素,特别是对于LinkedList这种非连续内存存储的数据结构,迭代器提供了一种高效且方便的方式来访问其元素。下面我们将深入探讨LinkedList...
迭代器模式是一种行为设计模式,主要目的是在不暴露集合内部结构的情况下,允许外部代码遍历集合的所有元素。这种模式将遍历操作从集合类中分离出来,实现了数据结构和遍历机制的解耦。在大多数编程语言中,迭代器...