ホームページ >バックエンド開発 >PHPチュートリアル >php_PHP チュートリアルでの浮動小数点数の正確な操作
bcはBinary Calculatorの略です。 bc* 関数のパラメーターは、すべてのオペランドにオプションの [intscale] を加えたものです (たとえば、string bcadd(string $left_operand, string $right_operand[, int $scale]) )。scale が指定されていない場合は、デフォルトの bcscale が使用されます。 。 価値。ここで、大きな数値は 0 ~ 9 の文字列で直接表現され、計算結果も文字列になります。
bcadd — 2 つの高精度数値を加算します
bccomp — 2 つの高精度数値を比較し、-1、0、1 を返します
bcdiv — 2 つの高精度数値を除算します
bcmod — 高精度の数値の余りを求めます
bcmul — 2 つの高精度数値を乗算します
bcpow — 高精度の数値の累乗を求めます
bcpowmod — 数論で非常に一般的に使用される、高精度の数値べき乗と係数を求めます
bcscale — デフォルトの小数点数を設定します。これは、Linux bc の "scale="
に相当します。
bcsqrt — 高精度の数値の平方根を求めます
bcsub — 2 つの高精度数値を減算します
まずコードを見てみましょう:
$a = 0.1;
$b = 0.7;
var_dump(($a + $b) == 0.8);
出力される値は実際にはブール値 false です
これはなぜですか? PHP マニュアルには、浮動小数点数に関する次の警告メッセージがあります。
警告
浮動小数点精度
0.1 や 0.7 のような単純な小数は、精度を少し損なうことなく内部バイナリ形式に変換できないようです。これは、混乱を招く結果につながる可能性があります。たとえば、floor((0.1+0.7)*10) は、結果の内部表現が 7.9999999999... のようなものであるため、通常、期待される 8 ではなく 7 を返します。
これは、有限の桁数で特定の小数を正確に表現することが不可能であるという事実と関係しています。たとえば、10 進数の 1/3 は 0.3333333 になります。
したがって、浮動小数点数の結果が最後の桁まで正確であると決して信じないでください。また、2 つの浮動小数点数が等しいかどうかを比較しないでください。本当により高い精度が必要な場合は、任意精度の数学関数または gmp 関数を使用する必要があります
$a = 0.1;
$b = 0.7;
var_dump(bcadd($a,$b,2) == 0.8);
)