ホームページ >ウェブフロントエンド >jsチュートリアル >js_javascript スキルの浮動小数点演算バグの解決手順

js_javascript スキルの浮動小数点演算バグの解決手順

WBOY
WBOYオリジナル
2016-05-16 17:05:191115ブラウズ

以前のプロジェクトでこのコードを見つけましたが、特定の条件下では依然として除算と加算の操作でバグが発生するため、これを個人的に少し最適化しました。

コードをコピー コードは次のとおりです:

//正確な除算結果を取得するために使用される除算関数
//説明: JavaScript の除算結果ではエラーになりますが、2 つの浮動小数点数を除算する場合にはより顕著になります。この関数は、より正確な除算結果を返します。
//呼び出し: accDiv(arg1, arg2)
//戻り値: arg1 を arg2 で除算した正確な結果
function accDiv(arg1, arg2) {
var t1 = 0, t2 = 0 , r1, r2;
try { t1 = arg1.toString().split(".")[1].length } catch (e) { }
try { t2 = arg2.toString(). split (".")[1].length } catch (e) { }
with (Math) {
r1 = Number(arg1.toString().replace(".", ""))
r2 = Number(arg2.toString().replace(".", ""))
return accMul((r1 / r2),pow(10, t2 - t1));
}
}

コードをコピー コードは次のとおりです:

/ /乗算関数、正確な乗算結果を取得するために使用されます
//説明: JavaScript の乗算結果にはエラーが発生します。これは、2 つの浮動小数点数を乗算するとより顕著になります。この関数は、より正確な乗算結果を返します。
//呼び出し: accMul(arg1, arg2)
//戻り値: arg1 と arg2 を乗算した正確な結果
function accMul(arg1, arg2) {
var m = 0, s1 = arg1 .toString(), s2 = arg2.toString();
try { m = s1.split(".")[1].length } catch (e) { }
try { m = s2. split (".")[1].length } catch (e) { }
return Number(s1.replace(".", "")) * Number(s2.replace(".", "") ) / Math.pow(10, m)
}

コードをコピー コードは次のとおりです

//加算演算の中間解
function accAdd(arg1, arg2) {
var r1, r2, m, c;
try { r1 = arg1. toString().split(".")[1].length } catch (e) { r1 = 0 }
try { r2 = arg2.toString().split(".")[1].length } catch (e) { r2 = 0 }
c = Math.abs(r1 - r2);
m = Math.pow(10, Math.max(r1, r2))
if (c > ; 0) {
var cm = Math.pow(10, c);
if (r1 > r2) {
arg1 = Number(arg1.toString().replace(".", " "));
arg2 = Number(arg2.toString().replace(".", "")) * cm;
} }
else {
arg1 = Number(arg1.toString) ().replace() ".", "")) * cm;
arg2 = Number(arg2.toString().replace(".", "")); { > arg1 = Number(arg1.toString().replace(".", ""));
arg2 = Number(arg2.toString().replace(".", "")); }
return accDiv((arg1 arg2),m)
}


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