查漏补缺1:快速失败与安全失败

快速失败与安全失败都是在集合遍历中的概念

快速失败

快速失败的核心思想是维护一个modCount字段。其实就是相当于一个版本号的功能,每当有线程对集合进行修改时,都会修改modCount的值。那在对集合进行遍历的时候,每次调用hasNext之前,都会查看这个modCount字段,如果和预期值不一样,说明遍历期间有其他线程并发访问了。此时会抛出一个Concurrent ModificationException异常

安全失败

安全失败是基于一种CopyOnWrite的思想。在进行读操作的时候不直接在原集合上进行,而是对原集合复制得到一个副本,读操作是基于副本上实现的。这样即使这期间有其他线程修改了集合,对当前线程来说也是不可见的。因为写操作和读操作是在不同的副本上进行的嘛。这就是安全失败。但安全失败的缺点就是在进行读操作的时候可能会导致内存翻倍,因为需要进行复制嘛~还有就是,读操作读到的数据不一定是最新的,因为读写分离,读操作对其它线程的更新操作是无法感知的。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章