2

以下代码:

    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));

呈现以下输出:

Double1 = 0,00
Double2 = 0,00
Double3 = 0,00
Float1  = 0,00
long1 = 0,00
long3 = 0,00

我现在读了很多关于浮点数和双精度数以及 Java 中没有的内容,但我似乎并不完全理解如何达到我想要的 0.6 的结果。

我究竟做错了什么?

4

3 回答 3

8

由于zahl1zahl2属于 类型int,因此以下内容:

double double1 = zahl1 / zahl2;

使用整数除法,其结果为0.

将结果分配给 type 的变量并不重要double:(整数)除法首先发生,然后其结果扩大到 a double

要修复,将该行更改为:

double double1 = zahl1 / (double)zahl2;
于 2012-05-21T13:10:44.110 回答
4

将整数除以另一个整数以浮动时,您必须强制转换:

(float)zahl1 / (float)zahl2

于 2012-05-21T13:10:53.673 回答
2

您应该查看BigDecimal类,该类提供 ROUND_HALF_DOWN 等功能以确保精度。

于 2012-05-21T13:12:47.660 回答