最新消息:雨落星辰是一个专注网站SEO优化、网站SEO诊断、搜索引擎研究、网络营销推广、网站策划运营及站长类的自媒体原创博客

javascript - Mysterious calculation error when multiply by 100 - Stack Overflow

programmeradmin3浏览0评论

The following script contains a very strange error. I want to check if a value is a positive integer. To do this, I multiply by 100 to enclose the value to decimal. If I test 0.07, the script does not calculated the value 7, but the value 7.00000001. I could round the value, but I would like to know why the value is calculated this way.

<script type="text/javascript">

  var isPositiveInt = function(i) {
        i = i*100;  
      return ((i % 1) == 0 && i >= 0);
  }; 

</script>

<a href="#" onclick="alert(isPositiveInt('0.07')); return false;">Try it out!</a>

0.05, 0.06 and 0.08 works fine. But what happens with 0.07? I would be happy if someone could explain that to me.

The following script contains a very strange error. I want to check if a value is a positive integer. To do this, I multiply by 100 to enclose the value to decimal. If I test 0.07, the script does not calculated the value 7, but the value 7.00000001. I could round the value, but I would like to know why the value is calculated this way.

<script type="text/javascript">

  var isPositiveInt = function(i) {
        i = i*100;  
      return ((i % 1) == 0 && i >= 0);
  }; 

</script>

<a href="#" onclick="alert(isPositiveInt('0.07')); return false;">Try it out!</a>

0.05, 0.06 and 0.08 works fine. But what happens with 0.07? I would be happy if someone could explain that to me.

Share Improve this question asked Jun 26, 2011 at 19:37 Tobias BambullisTobias Bambullis 2495 gold badges18 silver badges46 bronze badges 1
  • 1 This is just the way floating point arithmetic works. For a detailed discussion into the reasons, see this: scribd./doc/5836/… – James Allardice Commented Jun 26, 2011 at 19:40
Add a ment  | 

2 Answers 2

Reset to default 6

That's because javascript casts everything to a double internally. As a result, all calculations pick up some noise due to floating point inaccuracy: Floating point inaccuracy examples

One way to fix this issue, is to just round down to the nearest int after all intermediate calculations.

That's called numerical math. Computers do not operate on real numbers but on their approximation and this approximation brings rounding errors such as this one.

For 0.05, 0.06 and 0.08 you are lucky that these have an exact floating point representation on your PC. This is not the case of 0.07. Note that on a different PC/browser the result might be different.

For more info see the IEEE floating point format specification.

发布评论

评论列表(0)

  1. 暂无评论