java - 關(guān)于i++的一個(gè)題目
問題描述
使用2條線程對(duì)i=1進(jìn)行自增(i++),每條線程各自執(zhí)行100次,請(qǐng)問可能的最大值和最小值是多少?請(qǐng)給出解釋
另外問問,++i是否是原子性的?
問題解答
回答1:最小可以是 3,即 +2,最大 201,即 +200 。。。。為什么 i 不從 0 開始。。。
一次循環(huán)過程是:
從內(nèi)存讀取數(shù)據(jù)到寄存器
寄存器值++
寫回?cái)?shù)據(jù)到內(nèi)存
一個(gè)線程可能在這三步中的任意一步被打斷。是3的情況是:第一線程讀取數(shù)據(jù)1,然后被掛起,寄存器的值被保存到另一個(gè)地方。第二個(gè)線程,持續(xù)執(zhí)行了 99 次(此時(shí),內(nèi)存中的值為 100),然后被掛起。第一個(gè)線程被喚醒,恢復(fù)寄存器的 1 +1 之后 (=2)被寫回內(nèi)存,該線程被掛起第二個(gè)線程從內(nèi)存讀取2到寄存器之后被掛起第一個(gè)全部執(zhí)行完,把值寫回內(nèi)存喚起第二個(gè)線程,恢復(fù)寄存器中的2,完成最后一次循環(huán)+1 之后寫回 3
所以最終結(jié)果是 3。。。。
還沒有想到更小的調(diào)度方式。。。
最大值就不用過多解釋了。。。。
回答2:最小值為2,最大值為200。2就是兩個(gè)線程都在CPU緩存修改數(shù)據(jù),最終內(nèi)存只刷新了一次200 就是兩個(gè)線程交替讀取并修改,互相不競爭。都問最大值最小值了,自然不是原子性的。
相關(guān)文章:
1. thinkphp5.1學(xué)習(xí)時(shí)遇到session問題2. docker綁定了nginx端口 外部訪問不到3. docker網(wǎng)絡(luò)端口映射,沒有方便點(diǎn)的操作方法么?4. nignx - docker內(nèi)nginx 80端口被占用5. angular.js - angular內(nèi)容過長展開收起效果6. docker容器呢SSH為什么連不通呢?7. 前端 - ng-view不能加載進(jìn)模板8. docker images顯示的鏡像過多,狗眼被亮瞎了,怎么辦?9. javascript - iframe 為什么加載網(wǎng)頁的時(shí)候滾動(dòng)條這樣顯示?10. php - 第三方支付平臺(tái)在很短時(shí)間內(nèi)多次異步通知,訂單多次確認(rèn)收款
