javascript浮點數精確計算程式碼

antzone發表於2017-03-17

在浮點數進行加減乘除運算的時候會出現一些誤差,下面就介紹一下如何避免誤差實現精確計算。

一.加運算方式:

[JavaScript] 純文字檢視 複製程式碼
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  
}

arg1和arg2是要進行加運算的兩個浮點數。

二.減運算方式:

[JavaScript] 純文字檢視 複製程式碼
function accSub(arg1,arg2){ 
  return accAdd(arg1,-arg2); 
}

以上程式碼利用了加運算的程式碼,arg1和arg2是要進行減運算的兩個浮點數。

三.乘運算方式:

[JavaScript] 純文字檢視 複製程式碼
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)  
}

arg1和arg2是要進行乘法運算的兩個浮點數。

四.除運算方式:

[JavaScript] 純文字檢視 複製程式碼
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);  
  }  
}

arg1和arg2是要進行除法運算的兩個浮點數。

相關文章