PHP Float 計算の悪名高い精度の落とし穴
数値データを扱う場合、精度が最も重要です。ただし、PHP の float データ型は非常に扱いにくいことで知られており、計算に予期せぬ不正確さが生じる可能性があります。
次の PHP スニペットを考えてみましょう:
<code class="php">$fooValue = 100.68; $cowValue = 100.67; $diffValue = $fooValue - $cowValue; if($diffValue <= 0.01) { echo("success"); } else { echo("error"); }</code>
驚いたことに、このコードでは、代わりに "error" が出力されます。期待された「成功」。
原因: 浮動小数点数の不正確さ
原因は、浮動小数点データ型に固有の不正確さです。バイナリとの間で変換する場合、精度が失われる可能性があります。したがって、浮動小数点値が完全に等しいかどうかを比較することは信頼できない可能性があります。
高精度計算の解決策
この問題を解決するには、次のアプローチを検討してください:
追加のヒント:
以上がPHP Float 計算で「成功」ではなく「エラー」が発生するのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。