在Java集合的实现中,有一个modCount变量,这个变量在ArrayList中提供了比较详细的解释:
简单来说,就是这个变量表示了列表结构性改变的次数,结构性改变指的是列表大小发生变化,或者是其他方式改变列表内容,可能导致在遍历列表过程中得到错误的结果。
这个变量被iterator对象和list iterator对象使用(这两个对象在iterator()方法和listIterator()方法中实现),如果这个变量的值意外发生改变,iterator对象(或者listIterator对象)就会在next(),remove(), previous(), set(), add()这些函数中抛出一个ConcurrentModificationException,这样就实现了一种fail-fast行为,而不是在迭代过程中面对并发修改时的不确定行为。
是否在子类中使用这个变量是可选的,如果子类也想提供fail-fast行为,那么在自己的add, remove等修改列表结构的方法中增加这个变量的值,这些方法的一次调用增加这个变量的值不能超过1,否则迭代器对象就会抛出ConcurrentModificationException,如果不想在实现中提供fail-fast的迭代器,这个变量就可以忽略。
可以看出,这个变量存在的意义就是防止并发过程中,多个线程对同一个容器对象进行操作而导致错误结果。