已采納回答 / 特南克斯
main 線程是會和? new 出來的線程并行執行的,如果沒有那個 while 判斷,下面這行代碼<...code...>就會在其他線程執行完之前就執行了。加 while 判斷,就是為了等五百個線程執行完畢
2018-10-14
已采納回答 / 自有如風
你看看這樣能不能理解:number的值可以存在三個地方:主內存,cpu緩存,cpu寄存器。因為加上了volatile關鍵字,cpu每次對number的讀取都強迫cpu緩存從主內存中讀取。但是count++操作有三步,讀count,計算count+1,將計算的結果給count。假設讀count已經執行了,number已經放到了cpu寄存器中。此時當執行權被其他線程搶走之后再次輪到當前線程執行的時候,已經不需要再讀number了。故number還是沒有變化
2018-08-10
已采納回答 / 一葉秋才
這個Dome告訴你 編譯時可能存在其它結果,導致數據不安全
public?static?void?main(String[]?args)?{ ????SynchronizedDemo?synchronizedDemo=new?SynchronizedDemo(); ???????synchronizedDemo.new?ReadWriteThread(true).st...
2018-06-07
已采納回答 / annnn
A線程的工作變量里已經讀過number=5,B線程改變以后number=6后,的確會強迫store到主內存,但是這與A線程的工作變量無關,A線程讀取的時候已經load過了,不會主動再load,所以number=5
2018-03-18
已采納回答 / 憂傷的帥哥
不管怎么重排序(編譯器和處理器為了提高并行度),(單線程)程序的執行結果不能被改變。java內存中的變量都有指針引用,上下文引用成鏈,這個鏈是不會被打亂重排序的,只有沒有數據依賴關系的代碼,才會被沖排序,所以在單線程內部重排序不會改變程序運行結果,這就是as-if-serial
2017-06-22
已采納回答 / zvc888
每個線程都有一個自己的內存空間,當線程啟動的時候把變量從共享內存拷貝一份到私有內存,在這個變量更改后,需要push到共享內存,其他線程才能讀取到變量新的值;
2017-02-19