最新回答 / qq_慕設(shè)計1559327
as-if-serial:無論如何重排序,程序執(zhí)行的結(jié)果應(yīng)該與代碼順序執(zhí)行的結(jié)果一致。很明顯,2.1和2.2,進(jìn)行重排后,結(jié)果都是一樣的翻譯搜索復(fù)制
2022-08-09
最新回答 / 一個愛西瓜的小伙
synchronized分為對象鎖和類鎖。加在非靜態(tài)方法上的鎖是對象鎖,由于main中new了兩個實例,write和read方法是不同對象,因此兩個鎖不是同一把鎖,不具有互斥性。所以出現(xiàn)0和6的原因就是出現(xiàn)在處理器的重排序原因。兩個線程同時啟動,但是先執(zhí)行哪個線程是有處理器決定的。如果是讀線程先執(zhí)行,結(jié)果就是0;如果是寫線程先執(zhí)行就是6;如有問題請指正。
2019-11-24
最贊回答 / iceWang
一個或某幾個操作只能在一個線程執(zhí)行完之后,另一個線程才能開始執(zhí)行該操作,也就是說這些操作是不可分割的,線程不能在這些操作上交替執(zhí)行文中的 i++ 包括 3 個操作讀取 i 的值i 的值 +1?將 i 賦值給 i在這 3 個操作中可能會有其他線程開始執(zhí)行,因此不是原子性的
2019-01-20
最贊回答 / 慕前端6229441
共享變量是在多線程操作的情況下,對某一個變量都有進(jìn)行操作,該變量存儲在主存中,但是在多線程的工作內(nèi)存中都有一個副本,所以該變量是共享的,即為共享變量。
volatile變量是被該關(guān)鍵字修飾的變量。在單線程中也可以用來修飾變量,但是沒有意義。用在多線程中,是為了保證被其修飾的變量對于多線程來說都是內(nèi)存可見的。
在多線程中,volatile用來修飾共享變量,實現(xiàn)共享變量的可見性。
2018-08-12