javascript中的float運(yùn)算精度
標(biāo)簽:
JavaScript
有人问到一个js问题:
var i = 0.07; var r = i*100; alert(r);
结果为什么是7.0000000000000001?
查了下资料,其实我们知道JavsScript中,变量在存储时并不区分number和float类型,而是统一按float存储。而javascript使用IEEE 754-2008 标准定义的64bit浮点格式存储number,按照IEEE 754的定义: http://en.wikipedia.org/wiki/IEEE_754-2008
decimal64对应的整形部分长度为10,小数部分长度为16,所以默认的计算结果为“7.0000000000000001”,如最后一个小数为0,则取1作为有效数字标志。
类似地,我们可以想像,1/3的结果应该是0.3333333333333333。
那么如何校正这个值呢?
可以用以下方法:
一、parseInt
Code highlighting produced by Actipro CodeHighlighter (freeware)http://www.CodeHighlighter.com/-->var r4=parseInt(i*100);
二、Math.round
Code highlighting produced by Actipro CodeHighlighter (freeware)http://www.CodeHighlighter.com/-->var r2=Math.round((i*100)*1000)/1000;
以上两种方法都可以得到7
附全部测试代码:
<html> <head> <title>测试脚本</title> <script language="JAVASCRIPT"> function init() { var i = 0.07; var r = i*100; var r2=Math.round((i*100)*1000)/1000; var r3 = eval(i*100); var r4=parseInt(i*100); var r5=parseFloat(i*100*1.0000); var r6=(1/3); alert(r); alert("Math.round="+r2); alert("eval="+r3); alert("parseInt="+r4); alert("parseFloat="+r5); alert(""+r6); } </script> </head> <body onload="init();"> </body> </html>
點(diǎn)擊查看更多內(nèi)容
為 TA 點(diǎn)贊
評(píng)論
評(píng)論
共同學(xué)習(xí),寫下你的評(píng)論
評(píng)論加載中...
作者其他優(yōu)質(zhì)文章
正在加載中
感謝您的支持,我會(huì)繼續(xù)努力的~
掃碼打賞,你說多少就多少
贊賞金額會(huì)直接到老師賬戶
支付方式
打開微信掃一掃,即可進(jìn)行掃碼打賞哦