天天看點

Java中的strictfp關鍵字

strictfp

  Strictfp —— Java 關鍵字。

  strictfp, 即 strict float point (精确浮點)。

  strictfp 關鍵字可應用于類、接口或方法。使用 strictfp 關鍵字聲明一個方法時,該方法中所有的float和double表達式都嚴格遵守FP-strict的限制,符合IEEE-754規範。當對一個類或接口使用 strictfp 關鍵字時,該類中的所有代碼,包括嵌套類型中的初始設定值和代碼,都将嚴格地進行計算。嚴格限制意味着所有表達式的結果都必須是 IEEE 754 算法對操作數預期的結果,以單精度和雙精度格式表示。

  如果你想讓你的浮點運算更加精确,而且不會因為不同的硬體平台所執行的結果不一緻的話,可以用關鍵字strictfp.

  示例 1

下面的示例示範了一個使用 strictfp 修飾符聲明的類。

  

 

  示例輸出

  示例 2

  下面的示例示範了一個使用 strictfp 修飾符聲明的方法。

==============================================================

自Java2以來,Java語言增加了一個關鍵字strictfp。strictfp的意思是FP-strict,也就是說精确浮點的意思。在Java虛拟機進行浮點運算時,如果沒有指定strictfp關鍵字時,Java的編譯器以及運作環境在對浮點運算的表達式是采取一種近似于我行我素的行為來完成這些操作,以緻于得到的結果往往無法令你滿意。而一旦使用了strictfp來聲明一個類、接口或者方法時,那麼所聲明的範圍内Java的編譯器以及運作環境會完全依照浮點規範IEEE-754來執行。是以如果你想讓你的浮點運算更加精确,而且不會因為不同的硬體平台所執行的結果不一緻的話,那就請用關鍵字strictfp。

你可以将一個類、接口以及方法聲明為strictfp,但是不允許對接口中的方法以及構造函數聲明strictfp關鍵字,例如下面的代碼:

1. 合法的使用關鍵字strictfp

strictfp interface A ...{}

public strictfp class FpDemo1 ...{

strictfp void f() ...{}

}

2. 錯誤的使用方法

interface A ...{

strictfp void f();

public class FpDemo2 ...{

strictfp FpDemo2() ...{}

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