相关疑难解决方法(0)

这个简单的"双重"计算有什么问题?

在java中这个简单的"双重"计算有什么问题?

我知道一些十进制数字不能正确地用float/double二进制格式表示,但是使用变量d3,java能够存储并显示2.64而没有任何问题.

double d1 = 4.64;
double d2 = 2.0;
double d3 = 2.64;
double d4 = d1 - d2;

System.out.println("d1      : " + d1);
System.out.println("d2      : " + d2);
System.out.println("d3      : " + d3);
System.out.println("d4      : " + d4);
System.out.println("d1 - d2 : " + (d1 - d2));
Run Code Online (Sandbox Code Playgroud)

回答,

d1      : 4.64
d2      : 2.0
d3      : 2.64
d4      : 2.6399999999999997
d1 - d2 : 2.6399999999999997
Run Code Online (Sandbox Code Playgroud)

java double-precision

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

浮点加法 - 给出奇怪的结果..!

执行以下代码时:

public class FPoint {
    public static void main(String[] args) {
        float f = 0.1f;
        for(int i = 0; i<9; i++) {
            f += 0.1f;
        }
        System.out.println(f);
    }
}
Run Code Online (Sandbox Code Playgroud)

将显示以下输出:

1.0000001

但输出应该是1.0000000,对吗?如我错了请纠正我..!!

java floating-point floating-accuracy

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