亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

快速失敗迭代器內部如何工作?

快速失敗迭代器內部如何工作?

躍然一笑 2023-09-20 14:35:20
我知道什么是快速失敗和故障安全迭代器。如果集合發生結構修改,快速失敗迭代器會立即拋出 ConcurrentModificationException。故障安全在處理集合的克隆時不會引發任何異常。我的問題是快速失敗迭代器如何知道對我的集合進行了修改?
查看完整描述

2 回答

?
阿晨1998

TA貢獻2037條經驗 獲得超6個贊

你可以自己檢查一下實現情況。


讓我們考慮ArrayList一個例子。


它有一個內部Itr類,該iterator()方法返回該內部類的實例。


該類Itr有一個expectedModCount計數器,它是用封閉的ArrayList's初始化的modCount:


private class Itr implements Iterator<E> {

    int cursor;       // index of next element to return

    int lastRet = -1; // index of last element returned; -1 if no such

    int expectedModCount = modCount;

    ...

}

當您調用 的方法Iterator(例如next()或 )時remove(),它會調用該checkForComodification()方法:


    final void checkForComodification() {

        if (modCount != expectedModCount)

            throw new ConcurrentModificationException();

    }

如果自創建實例以來ArrayList'modCount已遞增,則會引發異常。Iterator


查看完整回答
反對 回復 2023-09-20
?
慕尼黑8549860

TA貢獻1818條經驗 獲得超11個贊

沒有單一的方法可以實現這一點。

ArrayList在(以及 中的其他類)的情況下java.util,迭代器保留一個int expectedModCount(“預期修改計數”),它與 的 (“修改計數”) 進行比較AbstractList,int modCount只要列表有結構修改,它就會更新;如果兩個值不同,迭代器將引發異常。


查看完整回答
反對 回復 2023-09-20
  • 2 回答
  • 0 關注
  • 121 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號