最新回答 / qq_慕設(shè)計(jì)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了兩個實(shí)例,write和read方法是不同對象,因此兩個鎖不是同一把鎖,不具有互斥性。所以出現(xiàn)0和6的原因就是出現(xiàn)在處理器的重排序原因。兩個線程同時啟動,但是先執(zhí)行哪個線程是有處理器決定的。如果是讀線程先執(zhí)行,結(jié)果就是0;如果是寫線程先執(zhí)行就是6;如有問題請指正。
2019-11-24
+ 我來回答
回答最高可+2積分
最贊回答 / iceWang
一個或某幾個操作只能在一個線程執(zhí)行完之后,另一個線程才能開始執(zhí)行該操作,也就是說這些操作是不可分割的,線程不能在這些操作上交替執(zhí)行文中的 i++ 包括 3 個操作讀取 i 的值i 的值 +1?將 i 賦值給 i在這 3 個操作中可能會有其他線程開始執(zhí)行,因此不是原子性的
2019-01-20
已采納回答 / 特南克斯
main 線程是會和? new 出來的線程并行執(zhí)行的,如果沒有那個 while 判斷,下面這行代碼<...code...>就會在其他線程執(zhí)行完之前就執(zhí)行了。加 while 判斷,就是為了等五百個線程執(zhí)行完畢
2018-10-14
最贊回答 / 慕前端6229441
共享變量是在多線程操作的情況下,對某一個變量都有進(jìn)行操作,該變量存儲在主存中,但是在多線程的工作內(nèi)存中都有一個副本,所以該變量是共享的,即為共享變量。
volatile變量是被該關(guān)鍵字修飾的變量。在單線程中也可以用來修飾變量,但是沒有意義。用在多線程中,是為了保證被其修飾的變量對于多線程來說都是內(nèi)存可見的。
在多線程中,volatile用來修飾共享變量,實(shí)現(xiàn)共享變量的可見性。
2018-08-12