Javascript在進行浮點數的乘積運算,會出現多位小數的情況。
這是由于在運算的時候先把浮點數轉化成二進制后進行運算,但是有的小數在二進制編碼后出現無限循環,因而導致計算出現了誤差,在其它變成語言中也有類似的問題。
原因解釋參考自百度知道:
例如:求1038.1-1000
1038.1=10000001110.0001100110011001100110011001100110011001100.....
1000 =1111101000
1038.1轉化為二進制是個無限循環小數,1100是循環節,只能取近似值,誤差就是這里產生的 如果瀏覽器版本高,可以用toFixed() 方法可把 Number 四舍五入為指定小數位數的數字。
解決方案:根據要保留的小數位數(如4),在計算乘積的時候先乘以(10^4),然后對計算結果除以(10^4),最后對結果取近似值Math.round
新聞熱點
疑難解答