Java中的transient,volatile和strictfp關鍵字
轉載來自:http://www.iteye.com/topic/52957 如果用transient聲明一個執行個體變數,當Object Storage Service時,它的值不需要維持。例如:
Java代碼 class T { transient int a; //不需要維持 int b; //需要維持 }
這裡,如果T類的一個對象寫入一個持久的儲存地區,a的內容不被儲存,但b的將被儲存。
volatile修飾符告訴編譯器被volatile修飾的變數可以被程式的其他部分改變。在多線程程式中,有時兩個或更多的線程共用一個相同的執行個體變數。考慮效率問題,每個線程可以自己儲存該共用變數的私人拷貝。實際的變數副本在不同的時候更新,如當進入synchronized方法時。
用strictfp修飾類或方法,可以確保浮點運算(以及所有切斷)正如早期的Java版本那樣準確。切斷隻影響某些操作的指數。當一個類被strictfp修飾,所有的方法自動被strictfp修飾。
strictfp的意思是FP-strict,也就是說精確浮點的意思。在Java虛擬機器進行浮點運算時,如果沒有指定strictfp關鍵字時,Java的編譯器以及運行環境在對浮點運算的運算式是採取一種近似於我行我素的行為來完成這些操作,以致於得到的結果往往無法令你滿意。而一旦使用了strictfp來聲明一個類、介面或者方法時,那麼所聲明的範圍內Java的編譯器以及運行環境會完全依照浮點規範IEEE-754來執行。因此如果你想讓你的浮點運算更加精確,而且不會因為不同的硬體平台所執行的結果不一致的話,那就請用關鍵字strictfp。
你可以將一個類、介面以及方法聲明為strictfp,但是不允許對介面中的方法以及建構函式聲明strictfp關鍵字,例如下面的代碼:
1. 合法的使用關鍵字strictfp
Java代碼 strictfp interface A {} public strictfp class FpDemo1 { strictfp void f() {} }
2. 錯誤的使用方法
Java代碼 interface A { strictfp void f(); } public class FpDemo2 { strictfp FpDemo2() {} }
一旦使用了關鍵字strictfp來聲明某個類、介面或者方法時,那麼在這個關鍵字所聲明的範圍內所有浮點運算都是精確的,符合IEEE-754規範的。例如一個類被聲明為strictfp,那麼該類中所有的方法都是strictfp的。
Keys: volatile
使用對象:欄位
介紹:因為非同步線程可以訪問欄位,所以有些最佳化操作是一定不能作用在欄位上的。volatile有時
可以代替synchronized。
Keys:transient
使用對象:欄位
介紹:欄位不是對象持久狀態的一部分,不應該把欄位和對象一起串起。