我正在用 Java 构建一个 Web 应用程序,它可以进行数学运算并向用户显示步骤。在使用小数进行基本算术运算时,我经常会在准确的输出中弄得一团糟。
这是我的问题:
double a = 0.15;
double b = 0.01;
System.out.println(a - b);
// outputs 0.13999999999999999
float a = 0.15;
float b = 0.01;
System.out.println(a - b);
// outputs 0.14
float a = 0.16f;
float b = 0.01f;
System.out.println(a - b);
// outputs 0.14999999
double a = 0.16;
double b = 0.01;
System.out.println(a - b);
// outputs 0.15
complete
两者的准确性都不可靠。是否有更精确的数字类,或者我应该将值四舍五入?