JVM的八大原子指令


JMM數據同步八大原子操作

lock(鎖定):作用於主內存的變量,把一個變量標記為一條線程獨占狀態

unlock(解鎖):作用於主內存的變量,把一個處於鎖定狀態的變量釋放出來,釋放后的變量才可以被其他線程鎖定

read(讀取):作用於主內存的變量,把一個變量值從主內存傳輸到線程的工作內存中,以便隨后的load動作使用

load(載入):作用於工作內存的變量,它把read操作從主內存中得到的變量值放入工作內存的變量副本中

use(使用):作用於工作內存的變量,把工作內存中的一個變量值傳遞給執行引擎

assign(賦值):作用於工作內存的變量,它把一個從執行引擎接收到的值賦給工作內存的變量

store(存儲):作用於工作內存的變量,把工作內存中的一個變量的值傳送到主內存中,以便隨后的write的操作

write(寫入):作用於工作內存的變量,它把store操作從工作內存中的一個變量的值傳送到主內存的變量中

一張圖整明白:

同步規則

1)不允許一個線程無原因地(沒有發生過任何assign操作)把數據從工作內存同步會主內存中

2)一個新的變量只能在主內存中誕生,不允許在工作內存中直接使用一個未被初始化(load或者assign)的變量。即就是對一個變量實施use和store操作之前,必須先自行assign和load操作。

3)一個變量在同一時刻只允許一條線程對其進行lock操作,但lock操作可以被同一線程重復執行多次,多次執行lock后,只有執行相同次數的unlock操作,變量才會被解鎖。lock和unlock必須成對出現。

4)如果對一個變量執行lock操作,將會清空工作內存中此變量的值,在執行引擎使用這個變量之前需要重新執行load或assign操作初始化變量的值。

5)如果一個變量事先沒有被lock操作鎖定,則不允許對它執行unlock操作;也不允許去unlock一個被其他線程鎖定的變量。

6)對一個變量執行unlock操作之前,必須先把此變量同步到主內存中(執行store和write操作)


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM