我正在閱讀Java Concurrency in Practice,根據其中的一些java代碼,System.out.println()
將導致ConcurrentModificationException
。代碼如下:爲什麼在使用System.out.println()打印一個集合時發生concurrentmodificationexception?
private final Set<Integer> set = new HashSet<Integer>();
public synchronized void add(Integer i) {set.add(i); }
public synchronized void remove(Integer i) {set.remove(i);}
public void addTenThings() {
Random r = new Random();
for (int i = 0; i < 10; i++) {
add(r.nextInt());
}
System.out.println("DEBUG: add ten elements to " + set);
}
由於System.out.println()
方法只會調用toString
方法:
public String toString() {
Iterator<E> i = iterator();
if (! i.hasNext())
return "[]";
StringBuilder sb = new StringBuilder();
sb.append('[');
for (;;) {
E e = i.next();
sb.append(e == this ? "(this Collection)" : e);
if (! i.hasNext())
return sb.append(']').toString();
sb.append(", ");
}
}
我仍然無法理解爲什麼ConcurrentModificationException
被扔?
您正在迭代集合,而另一個線程可能正在修改它。你的''+ set'調用'set'對象的toString() –