1. 程式人生 > >js浮點數的計算總結

js浮點數的計算總結

src .cn () log urn fun number lac 分開

在js浮點值的計算中,很多時候會出現不準確的情況,如下面的情況

console.log(2.2 + 2.1)          //  4.300000000000001
console.log(2.2 - 1.9)          // 0.30000000000000027
console.log(2.2 * 2.2)		// 4.840000000000001
console.log(2.1 / 0.3)		// 7.000000000000001
console.log(10 - 9.99)		// 0.009999999999999787

  然後上網找了一些解決辦法(參考博文底部鏈接),原理就是將浮點數從點號開始分開成兩個整數,然後進行計算。如下:

//加法
function add(a, b) { var c, d, e; try { c = a.toString().split(".")[1].length; } catch(f) { c = 0; } try { d = b.toString().split(".")[1].length; } catch(f) { d = 0; } return e = Math.pow(10, Math.max(c, d)), (mul(a, e) + mul(b, e)) / e; } //減法 function sub(a, b) { var c, d, e; try { c = a.toString().split(".")[1].length; } catch(f) { c = 0; } try { d = b.toString().split(".")[1].length; } catch(f) { d = 0; } return e = Math.pow(10, Math.max(c, d)), (mul(a, e) - mul(b, e)) / e; } //除法 function mul(a, b) { var c = 0, d = a.toString(), e = b.toString(); try { c += d.split(".")[1].length; } catch(f) {} try { c += e.split(".")[1].length; } catch(f) {} return Number(d.replace(".", "")) * Number(e.replace(".", "")) / Math.pow(10, c); } //乘法 function div(a, b) { var c, d, e = 0, f = 0; try { e = a.toString().split(".")[1].length; } catch(g) {} try { f = b.toString().split(".")[1].length; } catch(g) {} return c = Number(a.toString().replace(".", "")), d = Number(b.toString().replace(".", "")), mul(c / d, Math.pow(10, f - e)); }

 

  這個不失為一種很不錯的方法。但是當時做項目時好像只有一處地方用到,為了一處地方而粘貼這麽一段代碼,有點小題大作的感覺,後來我就臨時用了另一種方法,就先將浮點數乘以10的10次方變成整數,進行計算後將結果再除以10的10次方。結果如下。

技術分享

可以看出,該方法還是有效的,就是麻煩了點。值得註意的是,在除法那裏兩個值都乘以c之後,後面不需要再除以c,我犯了這個錯誤,所以我記下來了

好了,大概就這麽多了。

參考博客鏈接:http://blog.csdn.net/qinshenxue/article/details/43671763

js浮點數的計算總結