java | 您所在的位置:网站首页 › floatvalueof函数 › java |
我正在尝试将浮点数转换为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 .. 解决方法: 如果要避免损失任何精度,则必须始终使用BigDeciml,使用一点BigDecimal可能毫无意义. 我建议使用double,它具有十亿倍的精度(真的是?10 ^ 9 *) 如果要使用float,请不要使用Float,因为这只会增加开销,而没有任何好处. 如果执行13.846154,这已经比float支持更加精确. System.out.println(13.846155f); System.out.println(23.846155f); System.out.println(33.846155f);版画 13.846155 23.846155 33.846153 |
CopyRight 2018-2019 实验室设备网 版权所有 |