javascript中的float运算精度实例分析


Posted in Javascript onAugust 21, 2010

有人问到一个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>
Javascript 相关文章推荐
一个JS翻页效果
Jul 23 Javascript
js 设置选中行的样式的实现代码
May 24 Javascript
浅谈jQuery中 wrap() wrapAll() 与 wrapInner()的差异
Nov 12 Javascript
jQuery实现简单倒计时功能的方法
Jul 04 Javascript
原生js实现验证码功能
Mar 16 Javascript
jQuery实现动态添加、删除按钮及input输入框的方法
Apr 27 jQuery
给Easyui-Datebox设置隐藏或者不可用的解决方法
May 26 Javascript
Dropify.js图片宽高自适应的方法
Nov 27 Javascript
vue实现下拉加载其实没那么复杂
Aug 13 Javascript
jquery实现上传图片功能
Jun 29 jQuery
javascript实现点击小图显示大图
Nov 29 Javascript
代码块高亮可复制显示js插件highlight.js+clipboard.js整合
Feb 15 Javascript
Firebug入门指南(Firefox浏览器)
Aug 21 #Javascript
jquery插件之easing 动态菜单
Aug 21 #Javascript
url地址自动加#号问题说明
Aug 21 #Javascript
jquery中输入验证中一个不错的效果
Aug 21 #Javascript
单独使用CKFinder选择图片的方法
Aug 21 #Javascript
jQuery UI AutoComplete 自动完成使用小记
Aug 21 #Javascript
基于jQuery UI CSS Framework开发Widget的经验
Aug 21 #Javascript
You might like
2019十大人气国漫
2020/03/13 国漫
PHP 常见郁闷问题答解
2006/11/25 PHP
php绘制一个扇形的方法
2015/01/24 PHP
Discuz!X中SESSION机制实例详解
2015/09/23 PHP
基于PHP微信红包的算法探讨
2016/07/21 PHP
PHP crypt()函数的用法讲解
2019/02/15 PHP
javascript Split方法,indexOf方法、lastIndexOf 方法和substring 方法
2009/03/21 Javascript
深入理解JavaScript系列(14) 作用域链介绍(Scope Chain)
2012/04/12 Javascript
JQuery入门——用bind方法绑定事件处理函数应用介绍
2013/02/05 Javascript
AngularJS中的模块详解
2015/01/29 Javascript
js绘制购物车抛物线动画
2020/11/18 Javascript
jquery-mobile表单的创建方法详解
2016/11/23 Javascript
EasyUI Combobox设置默认值 获取text的方法
2016/11/28 Javascript
Bootstrap输入框组件简单实现代码
2017/03/06 Javascript
详解angularjs中的隔离作用域理解以及绑定策略
2017/05/31 Javascript
jquery实现图片放大点击切换
2017/06/06 jQuery
[53:43]VP vs NewBee Supermajor 胜者组 BO3 第三场 6.5
2018/06/06 DOTA
python如何实现远程控制电脑(结合微信)
2015/12/21 Python
Python之批量创建文件的实例讲解
2018/05/10 Python
python实现DEM数据的阴影生成的方法
2019/07/23 Python
Django 创建新App及其常用命令的实现方法
2019/08/04 Python
Matplotlib scatter绘制散点图的方法实现
2020/01/02 Python
Tensorflow的常用矩阵生成方式
2020/01/04 Python
Django操作session 的方法
2020/03/09 Python
Pytorch 使用不同版本的cuda的方法步骤
2020/04/02 Python
Python网页解析器使用实例详解
2020/05/30 Python
详解pyinstaller生成exe的闪退问题解决方案
2020/06/19 Python
CSS3实现网站商品展示效果图
2020/01/18 HTML / CSS
美国羊皮公司:Overland
2018/01/15 全球购物
全球最大的生存食品、水和装备专用在线市场:BePrepared.com
2020/01/02 全球购物
毕业研究生的自我鉴定
2013/11/30 职场文书
教师开学感言
2014/02/14 职场文书
小学见习报告
2015/06/23 职场文书
关于元旦的广播稿2016
2015/12/17 职场文书
告诉你一个秘密:富人致富的五大优点
2019/07/11 职场文书
python用tkinter开发的扫雷游戏
2021/06/01 Python