我读过很多关于stackoverflow的问题,但似乎没有一个对我有用。我使用math.round()来四舍五入。 这是代码:

class round{
    public static void main(String args[]){

    double a = 123.13698;
    double roundOff = Math.round(a*100)/100;

    System.out.println(roundOff);
}
}

我得到的输出是:123,但我希望它是123.14。我读到添加*100/100会有帮助,但正如你所看到的,我没有设法让它工作。

输入和输出都是double是绝对必要的。

如果您更改上面代码的第4行并发布它,将会有很大的帮助。


当前回答

double roundOff = Math.round(a*100)/100;

应该是

double roundOff = Math.round(a*100)/100D;

将'D'添加到100使其成为双字面量,因此产生的结果将具有精度

其他回答

我只是修改了你的代码。它在我的系统中工作得很好。看看这是否有用

class round{
    public static void main(String args[]){

    double a = 123.13698;
    double roundOff = Math.round(a*100)/100.00;

    System.out.println(roundOff);
}
}
BigDecimal a = new BigDecimal("123.13698");
BigDecimal roundOff = a.setScale(2, BigDecimal.ROUND_HALF_EVEN);
System.out.println(roundOff);

我知道这是一个2年前的问题,但每个人在某个时间点都面临着一个问题。我想分享一种不同的方法,通过使用BigDecimal类,可以给我们任何尺度的四舍五入值。在这里,如果我们使用DecimalFormat("0.00")或使用Math,我们可以避免获得最终值所需的额外步骤。整数(a * 100) / 100。

import java.math.BigDecimal;

public class RoundingNumbers {
    public static void main(String args[]){
        double number = 123.13698;
        int decimalsToConsider = 2;
        BigDecimal bigDecimal = new BigDecimal(number);
        BigDecimal roundedWithScale = bigDecimal.setScale(2, BigDecimal.ROUND_HALF_UP);
        System.out.println("Rounded value with setting scale = "+roundedWithScale);

        bigDecimal = new BigDecimal(number);
        BigDecimal roundedValueWithDivideLogic = bigDecimal.divide(BigDecimal.ONE,decimalsToConsider,BigDecimal.ROUND_HALF_UP);
        System.out.println("Rounded value with Dividing by one = "+roundedValueWithDivideLogic);

    }
}

这个程序会给我们以下的输出

Rounded value with setting scale = 123.14
Rounded value with Dividing by one = 123.14
public static float roundFloat(float in) {
    return ((int)((in*100f)+0.5f))/100f;
}

在大多数情况下应该没问题。例如,如果您希望与double类型兼容,您仍然可以更改类型。

回到你的代码,用100.00替换100,让我知道它是否有效。 然而,如果你想要正式一点,试试这个:

import java.text.DecimalFormat;
DecimalFormat df=new DecimalFormat("0.00");
String formate = df.format(value); 
double finalValue = (Double)df.parse(formate) ;