我正在閱讀 AbstractList 的代碼,其中有一個(gè)嵌套類 Itr,這很好。讓我困惑的是為什么Java為其Iterator提供了一組方法,以便可以使用它來修改底層集合,例如add(),,,remove()。set()必須將集合暴露給迭代器的根本原因是什么?它比通過 Collection 的方法修改集合更方便嗎?private class Itr implements Iterator<E> { //......bha public void remove() { if (lastRet < 0) throw new IllegalStateException(); checkForComodification(); try { AbstractList.this.remove(lastRet); if (lastRet < cursor) cursor--; lastRet = -1; expectedModCount = modCount; } catch (IndexOutOfBoundsException e) { throw new ConcurrentModificationException(); } }} private class ListItr extends Itr implements ListIterator<E> { ListItr(int index) { cursor = index; } public void set(E e) ///... public void add(E e) //.....
1 回答

開心每一天1111
TA貢獻(xiàn)1836條經(jīng)驗(yàn) 獲得超13個(gè)贊
如果在迭代時(shí)直接ConcurrentModificationException
修改集合,則很可能會(huì)得到 a ,因?yàn)榈骺赡軙?huì)變得無效。但如果你通過迭代器來完成,那么迭代器的實(shí)現(xiàn)可以確保它(迭代器)在修改后仍然有效。
但是,如果迭代器代碼不知道修改,則它無法執(zhí)行此操作,這就是您通過迭代器而不是直接執(zhí)行此操作的原因。
雖然可以設(shè)計(jì)集合和迭代器,直接修改集合將確保它使所有迭代器保持最新,但它要復(fù)雜得多,而且 JDK 設(shè)計(jì)者并沒有走這條路。
添加回答
舉報(bào)
0/150
提交
取消