第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

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

快速失敗迭代器內(nèi)部如何工作?

快速失敗迭代器內(nèi)部如何工作?

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

2 回答

?
阿晨1998

TA貢獻2037條經(jīng)驗 獲得超6個贊

你可以自己檢查一下實現(xiàn)情況。


讓我們考慮ArrayList一個例子。


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


該類Itr有一個expectedModCount計數(shù)器,它是用封閉的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;

    ...

}

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


    final void checkForComodification() {

        if (modCount != expectedModCount)

            throw new ConcurrentModificationException();

    }

如果自創(chuàng)建實例以來ArrayList'modCount已遞增,則會引發(fā)異常。Iterator


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

TA貢獻1818條經(jīng)驗 獲得超11個贊

沒有單一的方法可以實現(xiàn)這一點。

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


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

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網(wǎng)微信公眾號