java final域_final域_鲲鹏通用_TaiShan服务器代码移植参考_Java同步原语_华为云
使用final域標記的變量,編譯器和CPU需要遵守兩個重排序規則:
構造函數內對一個final域的寫入, 與隨后把該被構造對象的引用賦值給一個引用變量,這兩個操作不能重排序;
初次讀一個包含final域的對象的引用, 與隨后初次讀這個final域, 這兩個操作不能重排序。
寫入示例如下:
public class FinalDemo {
int i; // 普通變量
final int j; // final 變量
static FinalDemo obj;
public FinalDemo { // 構造函數
i = 1; // 寫普通域
j = 2; // 寫 final 域
}
public static void write() { // 寫線程 A 執行
obj = new FinalDemo();
}
public static void read() { // 讀線程 B 執行
FinalDemo object = obj; // 讀對象引用
int a = object.i; // 讀普通域
int b = object.j; // 讀 final 域
}
}
下圖是一種上述代碼的執行時序:
在圖中,寫普通域的操作被編譯器重排序到構造函數之外,線程B讀到了i未初始化的值。而寫final域的操作,被寫final域的重排序規則“限定”在了構造函數之內,線程B能正確讀到final變量初始后的值。
在圖中,讀對象的普通域被重排序到讀對象引用之前。讀普通域時,該域還沒被寫線程A寫入,這是一個錯誤的讀取操作。而final域的讀操作會被“限定”在對象引用之后,此時final域已經被正確初始化。
總結
以上是生活随笔為你收集整理的java final域_final域_鲲鹏通用_TaiShan服务器代码移植参考_Java同步原语_华为云的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: htpasswd java_mod_re
- 下一篇: linux openfire mysql