我需要格式化一个浮点数到小数点后n位。

尝试BigDecimal,但是返回值不正确…

public static float Redondear(float pNumero, int pCantidadDecimales) {
    // the function is call with the values Redondear(625.3f, 2)
    BigDecimal value = new BigDecimal(pNumero);
    value = value.setScale(pCantidadDecimales, RoundingMode.HALF_EVEN); // here the value is correct (625.30)
    return value.floatValue(); // but here the values is 625.3
}

我需要返回一个带有我指定的小数点后数位的浮点值。

我需要Float值返回而不是Double

.


当前回答

值得注意的是,不鼓励使用DecimalFormat构造函数。这个类的javadoc声明:

一般情况下,不要直接调用DecimalFormat构造函数,因为NumberFormat工厂方法可能返回DecimalFormat以外的子类。

https://docs.oracle.com/javase/8/docs/api/java/text/DecimalFormat.html

所以你需要做的是(例如):

NumberFormat formatter = NumberFormat.getInstance(Locale.US);
formatter.setMaximumFractionDigits(2);
formatter.setMinimumFractionDigits(2);
formatter.setRoundingMode(RoundingMode.HALF_UP); 
Float formatedFloat = new Float(formatter.format(floatValue));

其他回答

public static double roundToDouble(float d, int decimalPlace) {
        BigDecimal bd = new BigDecimal(Float.toString(d));
        bd = bd.setScale(decimalPlace, BigDecimal.ROUND_HALF_UP);
        return bd.doubleValue();
    }

值得注意的是,不鼓励使用DecimalFormat构造函数。这个类的javadoc声明:

一般情况下,不要直接调用DecimalFormat构造函数,因为NumberFormat工厂方法可能返回DecimalFormat以外的子类。

https://docs.oracle.com/javase/8/docs/api/java/text/DecimalFormat.html

所以你需要做的是(例如):

NumberFormat formatter = NumberFormat.getInstance(Locale.US);
formatter.setMaximumFractionDigits(2);
formatter.setMinimumFractionDigits(2);
formatter.setRoundingMode(RoundingMode.HALF_UP); 
Float formatedFloat = new Float(formatter.format(floatValue));

有点奇怪没有人指出直接的方法,这很简单。

double roundToDecimalPlaces(double value, int decimalPlaces)
{
      double shift = Math.pow(10,decimalPlaces);
      return Math.round(value*shift)/shift;
}

但我很确定这不会四舍五入。

无论如何,当您将基于二进制的浮点值与以10为基数的算术混合时,半偶数舍入将是混乱和不可预测的。我很确定这是不可能的。基本的问题是像1.105这样的值不能精确地用浮点数表示。浮点数的值是1.105000000000001,或者1.104999999999999。因此,任何执行半均匀舍入的尝试都会被表示性编码错误绊倒。

IEEE浮点实现会做半舍入,但他们做二进制半舍入,而不是十进制半舍入。所以你可能没事

我一直在寻找这个问题的答案,后来我发明了一种方法!:)一个公平的警告,它是四舍五入的值。

private float limitDigits(float number) {
    return Float.valueOf(String.format(Locale.getDefault(), "%.2f", number));
}

试试这个,这对我帮助很大

BigDecimal roundfinalPrice = new BigDecimal(5652.25622f).setScale(2,BigDecimal.ROUND_HALF_UP);

结果将是 roundfinalPrice—> 5652.26