簡體   English   中英

不同的舍入方法似乎不起作用

[英]Different rounding methods don't seem to work

以下代碼:

    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的結果。

我究竟做錯了什么?

由於zahl1zahl2的類型為int ,因此如下:

double double1 = zahl1 / zahl2;

使用整數除法 ,結果為0

將結果賦值給double類型的變量並不重要:首先發生(整數)除法,然后將其結果擴展為double

要修復,請將該行更改為:

double double1 = zahl1 / (double)zahl2;

在將其除以另一個整數浮動時,必須強制轉換整數:

(float)zahl1 / (float)zahl2

您應該檢查BigDecimal類,它提供了ROUND_HALF_DOWN等功能,以提高精度。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM