Java中的transient,volatile和strictfp關鍵字

若是用transient聲明一個實例變量,當對象存儲時,它的值不須要維持。例如: 
多線程

Java代碼  收藏代碼異步

  1. class T {  函數

  2.    transient int a;  //不須要維持  優化

  3.    int b;  //須要維持  spa

  4. }  .net


    這裏,若是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代碼  收藏代碼orm

  1. strictfp interface A {}  對象

  2.   

  3. public strictfp class FpDemo1 {  接口

  4.     strictfp void f() {}  

  5. }  


2. 錯誤的使用方法 

Java代碼  收藏代碼

  1. interface A {  

  2.     strictfp void f();  

  3. }  

  4.   

  5. public class FpDemo2 {  

  6.     strictfp FpDemo2() {}  

  7. }  


一旦使用了關鍵字strictfp來聲明某個類、接口或者方法時,那麼在這個關鍵字所聲明的範圍內全部浮點運算都是精確的,符合IEEE-754規範的。例如一個類被聲明爲strictfp,那麼該類中全部的方法都是strictfp的。 



Keys: volatile 

使用對象:字段 

介紹:由於異步線程能夠訪問字段,因此有些優化操做是必定不能做用在字段上的。volatile有時 

能夠代替synchronized。 




Keys:transient 

  使用對象:字段 

  介紹:字段不是對象持久狀態的一部分,不該該把字段和對象一塊兒串起。 

相關文章
相關標籤/搜索