ホームページ > 記事 > ウェブフロントエンド > javascript(js)_javascriptスキルの小数点の乗算と除算の問題を詳しく解説
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.
functiontran(){
args=tran.arguments;
vartemp=1;
for(i=0;i
for(i=0;i
returntemp
}
alert(tran(11,22.9));
//呼び出しをより便利にするために、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);
}