我正在尝试将浮点数转换为BigDecimal,然后进行一些数学运算.之后,我需要在Float中获得最终结果.
据我所知,使浮点数成为BigDecimal数字的唯一安全方法是使用字符串构造函数.
我有两种方法,但都没有用.两者都给我额外的0.000001值
方法1:
Float num1 = 13.846154f;
BigDecimal calculation = new BigDecimal(Float.toString(num1));
BigDecimal num2 = new BigDecimal("2.0").add(calculation);
Float finalResults = num2.floatValue();
方法2:
Float num1 = 13.846154f;
BigDecimal calculation = new BigDecimal(Float.toString(num1));
BigDecimal num2 = new BigDecimal("2.0").add(calculation);
Float finalResults = Float.parseFloat(num2.toString());
当我将数字转换回浮点数时,有没有一种方法可以安全地进行数学运算而又不会失去精度?
编辑#1
我做了一些测试,发现有些奇怪.
浮点数原始= 13.846154f;
BigDecimal originalNum = new BigDecimal(Float.valueOf(original));
BigDecimal numTwo = new BigDecimal("14.0");
BigDecimal numThree = new BigDecimal("20.0");
BigDecimal numFour = new BigDecimal("30.0");
numTwo = numTwo.add(originalNum);
numThree = numThree.add(originalNum);
numFour = numFour.add(originalNum);
它仍在添加额外的0.000001 ..