ホームページ >バックエンド開発 >PHPの問題 >PHP の乗算の不正確さを回避する方法

PHP の乗算の不正確さを回避する方法

PHPz
PHPzオリジナル
2023-03-27 18:15:181020ブラウズ

PHP は、サーバーサイド プログラミングで広く使用されているオープン ソース言語であり、その強力な機能と無料の機能により、Web サイト開発における重要なツールとなっています。ただし、PHP には優れたパフォーマンスと信頼性があるにもかかわらず、いくつかの欠点もあります。中でも乗算の不正確さの問題は見落とされやすい問題ですが、開発プロセスに大きな支障をきたす可能性があります。

PHP では、乗算は頻繁に使用される演算子であり、任意の 2 つの数値の積を計算するために使用できます。ただし、PHP では、2 つの数値の積が PHP の整数型の最大値を超えると、乗算の不正確さが発生します。 PHPでは整数型の最大値が2147483647であるため、2つの数値を乗算した結果がこの値を超えると不正な結果が発生します。

たとえば、次のコードは単純な PHP 乗算演算を示しています:

$num1 = 999999999;
$num2 = 123456789;

$result = $num1 * $num2;

echo $result;

実行結果は次のとおりです:

-6101065173502598407

実際には、正しい結果は 123456787654321111 となるはずです。これは、$num1 と $num2 を乗算すると、その結果が PHP の整数型の最大値を超えるためです。

PHPでは整数型で表現できる数値の範囲が限られているため、この範囲を超えるとエラーとなります。したがって、乗算演算を実行するときは、この不正確さの問題を回避するために特に注意する必要があります。乗算の不正確さの問題を回避するには、次のような方法があります。

  1. PHP が提供する BCMath 関数ライブラリを使用します。

BCMath 関数ライブラリは、高精度の関数のセットです。 PHP の数学関数を使用すると、PHP での整数の精度の損失の問題を解決できます。 BCMath 関数ライブラリを使用すると、PHP で高精度の数学演算を正確に実行できます。

  1. 数値を演算用の文字列に変換する

数値を演算用の文字列に変換すると、PHP での整数の精度の低下の問題を回避できます。これは、文字列操作が数値の範囲に制限されないためです。

たとえば、次のコードは文字列を使用した乗算の例を示しています:

$num1 = "999999999";
$num2 = "123456789";

$result = bcmul($num1, $num2);

echo $result;

実行結果は次のとおりです:

123456787654321111
  1. PHP 7 の新しい関数 intdiv の使用function

PHP 7 には新しい intdiv 関数があり、2 つの数値の整数商を正確に計算するために使用できます。 intdiv 関数を使用すると、整数の除算に関する精度の問題を回避できます。

たとえば、次のコードは、乗算に intdiv 関数を使用する例を示しています。

$num1 = 999999999;
$num2 = 123456789;

$result = intdiv($num1 * $num2, 1);

echo $result;

実行結果は次のとおりです。

123456787654321111

つまり、PHP は強力なアンオープンソース言語ですが、乗算演算を実行するときは、精度の損失を避けるために注意する必要があります。 BCMath ライブラリを使用するか、数値を算術用の文字列に変換するか、PHP 7 の intdiv 関数を使用することで、この問題を解決し、2 つの数値の積を正確に計算できます。

以上がPHP の乗算の不正確さを回避する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。