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進数の計算では、値を直接10,000倍に拡張し、それを10,000で割って問題を解決します。
ヴァルナム = 38.80;
var num2 = 13;
アラート(数値 * 10000 * 12 / 10000);
乗算と除算の数値が 10,000 より小さい場合、一部の数値では問題が発生することがテストで判明しています (1,000,000)。
二、
次のようにコードをコピーします。
<スクリプトの延期>
Number.prototype.rate=function(){
varoStr=this.toString();
if(oStr.indexOf(".")==-1)
戻り1;
それ以外
returnMath.pow(10,parseInt(oStr.length-oStr.indexOf(".")-1));
}
functiontran(){
args=tran.arguments;
vartemp=1;
for(i=0;i<args.length;i++)
temp*=args[i]*args[i].rate();
for(i=0;i<args.length;i++)
temp/=args[i].rate();
戻り温度
}
アラート(tran(11,22.9));
</script>
この解決策は少し面倒ですが、この問題を解決する実際のプロセスを理解することができます。
次のようにコードをコピーします。
//除算関数。正確な除算結果を取得するために使用されます。
//注: JavaScript の除算結果にはエラーが発生します。これは、2 つの浮動小数点数を除算する場合にさらに顕著になります。この関数は、より正確な除算結果を返します。
//呼び出し: accDiv(arg1,arg2)
//戻り値: arg1 を arg2 で割った正確な結果
関数 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(数学){
r1=数値(arg1.toString().replace(".",""))
r2=数値(arg2.toString().replace(".",""))
return (r1/r2)*pow(10,t2-t1);
}
}
//呼び出しをより便利にするために、Div メソッドを Number 型に追加します。
Number.prototype.div = 関数 (引数){
戻り accDiv(this, arg);
}
// 正確な乗算結果を取得するために使用される乗算関数
//注: JavaScript の乗算結果にはエラーが発生します。これは、2 つの浮動小数点数を乗算するとより顕著になります。この関数は、より正確な乗算結果を返します。
//呼び出し: accMul(arg1,arg2)
//戻り値: arg1 と arg2 を乗算した正確な結果
関数 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 = 関数 (引数){
return accMul(arg, this);
}
//正確な加算結果を取得するために使用される加算関数
//注: JavaScript の加算結果にはエラーが発生します。これは、2 つの浮動小数点数を加算する場合にさらに顕著になります。この関数は、より正確な加算結果を返します。
//呼び出し: accAdd(arg1,arg2)
// 戻り値: arg1 と arg2 の正確な結果
関数 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 = 関数 (引数){
戻り accAdd(arg,this);
}