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