文章详情

  • 游戏榜单
  • 软件榜单
关闭导航
热搜榜
热门下载
热门标签
php爱好者> php文档>javascript中的float运算精度

javascript中的float运算精度

时间:2010-08-20  来源:邀月

有人问到一个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

var r4=parseInt(i*100);

 

二、Math.round

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>

 

 

 

相关阅读 更多 +
排行榜 更多 +
辰域智控app

辰域智控app

系统工具 下载
网医联盟app

网医联盟app

运动健身 下载
汇丰汇选App

汇丰汇选App

金融理财 下载