ホームページ  >  記事  >  ウェブフロントエンド  >  javascript(js)_javascriptスキルの小数点の乗算と除算の問題を詳しく解説

javascript(js)_javascriptスキルの小数点の乗算と除算の問題を詳しく解説

WBOY
WBOYオリジナル
2016-05-16 16:56:401435ブラウズ

1. js を使用して
12.32 * 7 を計算すると、結果はどうなるでしょうか?答え: 86.24000000000001

なぜこの問題が発生するのでしょうか?どうやって解決すればいいでしょうか?
小数の乗算と除算を処理するときに js にバグがあります。解決策としては、小数を整数に変換して処理します。
上記の計算は次のように変更できます:
12.32 * 100 * 7 /100
結果は次のようになります: 86.24、正解です。

また計算します:
8.80 * 100 * 12 / 100
結果: 105.60000000000002
38.80 同様の問題も発生します。

精度が 10 倍増加:
8.80 * 1000 * 12 / 1000
結果: 105.6
通常。

16.40 * 1000000 * 6 / 1000000
結果にも問題があります

js の実行をより正確にするために、今後の js 10 進数の計算では、値を直接 10000 倍に拡張し、その後 10000 で除算して問題を解決します。
var num = 38.80;
var num2 = 13;
alert(num * 10000 * 12 / 10000);

乗算と除算の数値は 10,000 であることがテストされており、それより小さい場合は一部の数値で問題が発生し、それより大きい場合 (1,000,000) で一部の数値でも問題が発生します。

2.

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

<スクリプト遅延>
Number.prototype.rate=function(){
varoStr=this.toString();
if(oStr.indexOf("." )==- 1)
return1;
else
returnMath.pow(10,parseInt(oStr.length-oStr.indexOf(".")-1));
}

functiontran(){
args=tran.arguments;
vartemp=1;
for(i=0;itemp*=args[i] *args[i].rate();
for(i=0;itemp/=args[i].rate();
returntemp
}
alert(tran(11,22.9));


この解決策はさらに面倒ですが、解決方法の一般的なアイデアを得ることができます。この実際のプロセス。
コードをコピー コードは次のとおりです:

//精度を得るために使用される除算関数除算結果
//注: 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 (r1/r2)*pow(10,t2-t1);
}
}

//呼び出しをより便利にするために、Div メソッドを Number 型に追加します。
Number.prototype.div = function (arg){
return accDiv(this, arg);
}

//正確な乗算結果を取得するために使用される乗算関数
//説明: 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)
}

// 呼び出しをより便利にするために、Number 型に mul メソッドを追加します。
Number.prototype.mul = function (arg){
return accMul(arg, this);
}

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

//呼び出しをより便利にするために、Number 型に add メソッドを追加します。
Number.prototype.add = function (arg){
return accAdd(arg,this);
}

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