相关疑难解决方法(0)

为什么打印最后一个数字(1)?

代码:

<?php
$start = 0;
$stop  = 1;
$step = ($stop - $start)/10;
$i = $start + $step;
while ($i < $stop) {
    echo($i . "<br/>");
    $i += $step;
}
?>
Run Code Online (Sandbox Code Playgroud)

输出:

0.1
0.2
0.3
0.4
0.5
0.6
0.7
0.8
0.9
1 <-- notice the 1 printed when it shouldn't
Run Code Online (Sandbox Code Playgroud)

创造了一个小提琴

还有一个:如果设置$start = 1$stop = 2它工作正常.

使用: php 5.3.27

为什么1印刷?

php floating-point

41
推荐指数
2
解决办法
1197
查看次数

Java中的浮点数的精度错误

我想知道在Java中修复精度错误的最佳方法是什么.正如您在以下示例中所看到的,存在精度错误:

class FloatTest
{
  public static void main(String[] args)
  {
    Float number1 = 1.89f;

    for(int i = 11; i < 800; i*=2)
    {
      System.out.println("loop value: " + i);
      System.out.println(i*number1);
      System.out.println("");
    }
  }
}
Run Code Online (Sandbox Code Playgroud)

显示的结果是:

循环值:11

20.789999

循环值:22

41.579998

循环值:44

83.159996

循环值:88

166.31999

循环值:176

332.63998

循环值:352

665.27997

循环值:704

1330.5599

此外,如果有人可以解释为什么它只从11开始并且每次都加倍.我认为所有其他值(或至少其中许多值)显示正确的结果.

这样的问题让我头疼,我通常使用数字格式化程序或将它们放入String中.

编辑:正如人们提到的,我可以使用双,但在尝试之后,似乎1.89作为双倍792仍然输出错误(输出为1496.8799999999999).

我想我会尝试其他解决方案,比如BigDecimal

java floating-point precision

10
推荐指数
2
解决办法
3万
查看次数

Java:双打不正常显示

我正在尝试计算以下两个双打的乘积:

double x = 196.0d;
double y = 0.5144d;

double z = x * y;
Run Code Online (Sandbox Code Playgroud)

答案应该是,z = 100.8224;但java计算它z = 100.82239999999999;

是什么造成的?

java multiplication

1
推荐指数
1
解决办法
223
查看次数

减去两个十进制数字,给出奇怪的输出

虽然我很开心Java Puzzlers的代码(我没有这本书),但我遇到了这段代码

public static void main(String args[]) {
        System.out.println(2.00 - 1.10);
    }
Run Code Online (Sandbox Code Playgroud)

输出是

0.8999999999999999
Run Code Online (Sandbox Code Playgroud)

当我尝试将代码更改为

2.00d - 1.10d 我仍然得到相同的输出 0.8999999999999999

对于,2.00d - 1.10f输出为0.8999999761581421
For,2.00f - 1.10d输出为0.8999999999999999
For,2.00f - 1.10fOutput为0.9

为什么我不能像0.9第一个那样获得输出?我不能用这个做任何头或尾?有人可以清楚说明这一点吗?

java floating-point

-3
推荐指数
2
解决办法
1281
查看次数

标签 统计

floating-point ×3

java ×3

multiplication ×1

php ×1

precision ×1