我需要格式化一个浮点数到小数点后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
.
有点奇怪没有人指出直接的方法,这很简单。
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浮点实现会做半舍入,但他们做二进制半舍入,而不是十进制半舍入。所以你可能没事
值得注意的是,不鼓励使用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));