当前位置:首页 > Java技术 > Java使用BigDecimal精度丢失问题

Java使用BigDecimal精度丢失问题

2022年08月05日 01:41:34Java技术4

在实际应用中,经常会使用到计算,特别是在企业用途上,计算的结果往往要求的更加精确,这是我们就会使用到java.math包中提供的API类BigDecimal,用于对超过16位有效位数的数字进行精确的计算;

下列为使用时出现的问题:

// 运行测试代码
public class Test {

    public static void main(String[] args) {

        System.out.println("使用bigDecimal进行转换---》》》》"+new BigDecimal(113.880));

    }

}

运行后的结果出现精度丢失:
Java使用BigDecimal精度丢失问题 _ JavaClub全栈架构师技术笔记

从结果可以看出使用new BigDecimal(113.880),传入参数为double类型发生精度丢失,运行的结果并不是正好等于113.880,而是为113.8799999999999954525264911353588104248046875

原因是double不能表示为任何有限长度的二进制小数;

解决方式:

    使用new BigDecimal(String)构造函数,创建一个参数以字符串表示数值的对象
public class Test {

    public static void main(String[] args) {

        double a = 113.880;

        String b = "113.880";

        // 方式一:double的封装类Double中的toString()方法解决
        System.out.println("使用bigDecimal进行转换---》》》》" + new BigDecimal(new Double(a).toString()));

        // 方式二:使用String接收数值
        System.out.println("使用bigDecimal进行转换---》》》》" + new BigDecimal(b));

    }

}

结果如下:
Java使用BigDecimal精度丢失问题 _ JavaClub全栈架构师技术笔记

这样就能解决使用BigDecimal出现的精度丢失问题了,如果还需使用加减乘除方法运算,可以使用BigDecimal类提供的add、subtract、multiply、divide方法实现;

float和double主要用来处理科学计算和工程计算

如果有更好的方式可以提出,希望可以帮助到正在学习的你

作者:programmer-阿杰
来源链接:https://blog.csdn.net/qq_35525955/article/details/81317898

版权声明:
1、JavaClub(https://www.javaclub.cn)以学习交流为目的,由作者投稿、网友推荐和小编整理收藏优秀的IT技术及相关内容,包括但不限于文字、图片、音频、视频、软件、程序等,其均来自互联网,本站不享有版权,版权归原作者所有。

2、本站提供的内容仅用于个人学习、研究或欣赏,以及其他非商业性或非盈利性用途,但同时应遵守著作权法及其他相关法律的规定,不得侵犯相关权利人及本网站的合法权利。
3、本网站内容原作者如不愿意在本网站刊登内容,请及时通知本站(javaclubcn@163.com),我们将第一时间核实后及时予以删除。


本文链接:https://www.javaclub.cn/java/17788.html

标签: BigDecimal
分享给朋友:

“Java使用BigDecimal精度丢失问题” 的相关文章

Java 使用BigDecimal进行高精度加减乘除

有时候我们计算金钱或者其他一些计算的时候需要高精度的计算加减乘除,可以使用BigDecimal 加: BigDecimal num1 = new BigDecimal("100.569"); BigDecimal num2 = new Big...

[转]BigDecimal使用(整理)

原文地址:https://www.jianshu.com/p/2947868d76eb 应用场景 大多数的商业计算中,一般采用java.math.BigDecimal类来进行精确计算。比如:货币 使用 1、构建BigDecima...

Java:利用BigDecimal类巧妙处理Double类型精度丢失

Java:利用BigDecimal类巧妙处理Double类型精度丢失

文章目录 本篇要点 经典问题:浮点数精度丢失 十进制整数如何转化为二进制整数? 十进制小数如何转化为二进制数?...

BigDecimal 与 doubleValue 的使用 ,以及四舍五入

/** * 保存发票信息 * @param controller * @return * @throws ParseException * @throws ActiveRecordException */ @...

BigDecimal转为int类型

BigDecimal转为int类型

直接调用BigDecimal的intValue()方法 示例: BigDecimal a = new BigDecimal(“1.1”); int b = a.intValue(); BigDecimal运算方法:...

JDK中BigDecimal的代码实现

package java.math; import java.io.IOException;import java.io.ObjectInputStream;import java.io.ObjectOutputStream;import java.io.PrintStream;...

Java BigDecimal

1构造函数(主要测试参数类型为double和String的两个常用构造函数)        BigDecimal aDouble =new BigDecimal(1.22);  &nb...

BigDecimal 使用compareTo比较大小

1.BigDecimal的比较模式  BigDecimal b1 = new BigDecimal(0.1); BigDecimal b2 = new BigDecimal(0.2); int c = b1.compareTo(b2); // -1 c=1表示...

【java提高】(19)---BigDecimal详解和精度问题

【java提高】(19)---BigDecimal详解和精度问题

BigDecimal详解和精度问题 一、背景 在实际开发中,对于 不需要任何准确计算精度的属性可以直接使用float或double,但是如果需要精确计算结果,则必须使用BigDecimal,例如价格、质量。 为什么这么说,主要有两点...

BigDecimal<转载>

前言 我们都知道浮点型变量在进行计算的时候会出现丢失精度的问题。如下一段代码: System.out.println(0.05 + 0.01); System.out.println(1.0 - 0.42); System.out.printl...

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。