java8之前list的迭代和增删如果不使用同步锁是会报错的:Exception in thread "Thread-0" java.util.ConcurrentModificationException
这是因为如果不同的线程同时访问同一个list的时候,迭代器中的唯一标识将会失效,此时就会报错。形象一点,如果点名的时候,一个本应该在职的员工却不在了,那就是出错了。点名和辞职,这是两件事,同时做就会出错。
在java8中list.foreach就很好的解决了这个问题,它的原理也很简单,使用的是迭代器当中的modCount作为标识符,每次对元素操作时保证是最新的。
这是源码:
@Override
public void forEach(Consumer<? super E> action) {
Objects.requireNonNull(action);
final int expectedModCount = modCount;
@SuppressWarnings("unchecked")
final E[] elementData = (E[]) this.elementData;
final int size = this.size;
for (int i=0; modCount == expectedModCount && i < size; i++) {
action.accept(elementData[i]);
}
if (modCount != expectedModCount) {
throw new ConcurrentModificationException();
}
}