atr*_*pes 2 java floating-point double rounding
以下代码:
DecimalFormat df = new DecimalFormat();
df.setMinimumFractionDigits(2);
int zahl1 = 10;
int zahl2 = 18;
double double1 = zahl1 / zahl2;
System.out.println("Double1 = " + df.format(double1));
double double2 = Math.ceil(zahl1 / zahl2);
System.out.println("Double2 = " + df.format(double2));
double double3 = Math.round((zahl1 / zahl2) * 100) / 100;
System.out.println("Double3 = " + df.format(double3));
float float1 = Math.round((zahl1 / zahl2) * 100) / 100;
System.out.println("Float1 = " + df.format(float1));
long long1 = zahl1 / zahl2;
System.out.println("long1 = " + df.format(long1));
long long3 = Math.round((zahl1 / zahl2) * 100) / 100;
System.out.println("long3 = " + df.format(long3));
Run Code Online (Sandbox Code Playgroud)
呈现以下输出:
Double1 = 0,00
Double2 = 0,00
Double3 = 0,00
Float1 = 0,00
long1 = 0,00
long3 = 0,00
Run Code Online (Sandbox Code Playgroud)
我现在读了很多关于浮点数和双打以及什么不是Java的内容,但我似乎并不完全理解如何达到我期望的0.6的结果.
我究竟做错了什么?
由于zahl1和zahl2是类型int,以下:
double double1 = zahl1 / zahl2;
Run Code Online (Sandbox Code Playgroud)
使用整数除法,结果是0.
将结果赋值给类型变量并不重要double:首先发生(整数)除法,然后将其结果扩展为a double.
要修复,请将该行更改为:
double double1 = zahl1 / (double)zahl2;
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
101 次 |
| 最近记录: |