java 您所在的位置:网站首页 floatvalueof函数 java

java

2023-03-19 12:46| 来源: 网络整理| 查看: 265

我正在尝试将浮点数转换为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 实验室设备网 版权所有