我正在學(xué)習(xí)CopyOnWriteArrayList,下面的情況讓我思考。我的主要方法是這樣的:public static void main(String[] args) { List<String> list = new CopyOnWriteArrayList<String>(); list.add("Init1"); list.add("Init2"); list.add("Init3"); list.add("Init4"); for(String str : list){ System.out.println(str); list.add("PostInit"); } }在 javadoc 中我讀到:內(nèi)存一致性影響:與其他并發(fā)集合一樣,在將對(duì)象放入 CopyOnWriteArrayList 之前線程中的操作發(fā)生在另一個(gè)線程中從 CopyOnWriteArrayList 訪問或刪除該元素之后的操作。我期待一個(gè)無限循環(huán),因?yàn)椤霸趯?duì)象放入 CopyOnWriteArrayList 之前線程中的操作發(fā)生在訪問或刪除之后的操作之前”。但是我的控制臺(tái)輸出是:Init1Init2Init3Init4我相信,我在這里缺乏一些了解。有人可以幫忙嗎?
1 回答

眼眸繁星
TA貢獻(xiàn)1873條經(jīng)驗(yàn) 獲得超9個(gè)贊
從文檔
“快照”樣式的迭代器方法在創(chuàng)建迭代器時(shí)使用對(duì)數(shù)組狀態(tài)的引用。這個(gè)數(shù)組在迭代器的生命周期內(nèi)永遠(yuǎn)不會(huì)改變,所以干擾是不可能的,迭代器保證不會(huì)拋出 ConcurrentModificationException。迭代器不會(huì)反映自迭代器創(chuàng)建以來對(duì)列表的添加、刪除或更改
for-each 循環(huán)使用迭代器
因此,for-each 循環(huán)將在 for 循環(huán)開始時(shí)打印列表中的元素,因?yàn)樗窃趧?chuàng)建迭代器的那一刻。
添加回答
舉報(bào)
0/150
提交
取消