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