ホームページ >ウェブフロントエンド >フロントエンドQ&A >JavaScript の操作精度が失われるとどうなりますか?

JavaScript の操作精度が失われるとどうなりますか?

PHPz
PHPzオリジナル
2023-04-21 10:01:321131ブラウズ

JavaScript コードを作成するとき、計算精度が失われるという問題に遭遇する可能性があります。このような状況に直面した場合は、その原因を理解し、適切な対策を講じる必要があります。

まず、JavaScript では数値を表すために IEEE 754 標準の浮動小数点型を使用することを知っておく必要があります。このタイプのメモリには、表現できる数値の範囲とその精度が固定されています。浮動小数点数型は精度が固定されているため、演算結果がその範囲を超えると精度が落ちる場合があります。

たとえば、より大きな数値を演算する場合、後ろの小数部分が省略され、結果が不正確になる可能性があります。さらに、より小さい数値を演算すると丸め誤差が発生し、結果も不正確になる可能性があります。

浮動小数点演算を実行するときは、次の点に注意する必要があります。

  1. 小数演算の使用は避けるようにしてください。
  2. 整数型を使用して演算を実行し、その結果を浮動小数点型に変換できます。
  3. 浮動小数点演算で発生する可能性のある精度誤差をできる限り減らします。たとえば、toFixed メソッドを使用します。

次は簡単な例です:

let total = 0.1 + 0.2; // 结果应该是 0.3
console.log(total); // 输出 0.30000000000000004

この例では、浮動小数点演算を使用して 0.1 と 0.2 の合計を計算しますが、出力結果は 0.30000000000000004 です。これは、0.1 と 0.2 はどちらも無限に繰り返される 10 進数であり、浮動小数点型では限られた数の数値しか正確に表現できないためです。したがって、浮動小数点型はこれらの数値を最も近い有限数に近似して表すことになり、精度が失われるという問題が発生します。

この問題を解決するには、toFixed メソッドを使用して、出力結果を小数点以下の桁数に四捨五入します。たとえば、次のようになります。

let total = 0.1 + 0.2; // 结果应该是 0.3
console.log(total.toFixed(1)); // 输出 0.3

toFixed メソッドを使用して、合計を切り捨てます。小数点以下の桁数が少ないため、出力は正しい結果になります。したがって、JavaScript プログラムを作成するときは、浮動小数点演算の使用を最小限に抑え、必要に応じて toFixed メソッドを使用して、精度の低下の問題を回避する必要があります。 。

つまり、JavaScript 浮動小数点数型の内部表現を理解し、コードを記述するときに精度の低下を避けるように注意する必要があります。場合によっては、この問題を回避するために、整数型を使用して演算を実行し、結果を浮動小数点型に変換するなど、特別なテクニックを使用する必要があります。どの方法を使用する場合でも、コードを作成する際には、コードの正確性を確保するために常に精度の問題に注意を払う必要があります。

以上がJavaScript の操作精度が失われるとどうなりますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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