当前位置:首页 > Java技术 > BigDecimal详解

BigDecimal详解

2022年08月05日 21:42:04Java技术8

一.讨论这个问题的缘由

经常会遇到浮点数溢出的问题,这个问题在前端和后端的代码中都多次出现过,因为业务涉及金钱,给用户展示一个溢出的结果肯定会引起误解和不满,因此程序员在编码的时候应该尽量避免这个问题。

出现浮点数溢出的根本原因在与计算机不能准确保存某些小数,float保存的是32位二进制数,double保存的是64位二进制数,在保存某些小数的过程中不可避免的进行了截断

二.解决的方法——使用java.math.BigDecimal

BIgDecimal是如何解决浮点数问题的?

先引入BigDecimal的原理:BigDecimal不使用二进制,而是使用十进制(BigDecimal)+小数点位置(scale)来表示小数,整数部分使用能实现任意精度的BigInteger表示,小数点位置使用一个整数表示

BigInteger能实现任意精度的原理:

在下面这段代码的这行结果为513,mg是一个Byte数字,用二进制可以将数组元素表示为[00000010,00000001]用这个数组表示1000000001这个二进制数,转换成十进制是513

1
2
3
4
5
6
7
public  class  UseBigDecimal {
     public  static  void  main(String args[])
     {
         byte [] mg = { 2 , 1 };
         System.out.println( new  BigInteger(mg));
     }
}

三.BigDecimal的使用及其注意事项

BigDecimal的构造方法:

BigDecimal(int):将int表示形式转换成BigDecimal对象

BigDecimal(double):将double表示形式转换成BigDecimal对象

BigDecimal(String):将String表示形式转换成BigDecimal对象

BigDecimal的常用方法:

add(BigDecimal):BigDecimal对象的值相加,返回BigDecimal对象

subtract(BigDecimal):BigDecimal对象的值相减,返回BigDecimal对象

multiply(BigDecimal):BigDecimal对象的值相乘,返回BigDecimal对象

divide(BigDecimal):BigDecimal对象的值相除,返回BigDecimal对象

toString():将BigDecimal中的值转为字符串

doubleValue():将BigDecimal中的值转为字符串

intValue():将BigDecimal中的值转为int

longValue():将BigDecimal中的值转long

floatValue():将BigDecimal中的值转为float

运行以下代码时发现:

1
2
3
4
5
6
7
public  static  void  main(String args[])
{
     BigDecimal f1 =  new  BigDecimal( "0.05" );
     BigDecimal f3 =  new  BigDecimal( 0.05 );
     System.out.println(f1.add(f1));
     System.out.println(f3.add(f3));
}
结果:0.10
         0.10000000000000000555111512312578270211815834045410156250

总结:要保证精度就不能用double/float,而必须使用BigDecimal,并且不能直接double转BigDecimal,需要将double转string在转BigDecimal。还有另一种方法,使用java.math.BigDecimal.valueof(double val)转换double为一个BigDecimal

【参考】

https://yq.aliyun.com/articles/20309



作者:for_choc
来源链接:https://blog.csdn.net/for_choc/article/details/79307486

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

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


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

标签: BigDecimal
分享给朋友:

“BigDecimal详解” 的相关文章

java.math.BigDecimal常用方法

+构造函数 BigDecimal(BigInteger val) 将BigInteger转化为BigDecimal。 BigDecimal(BigInteger unscaledVal, int scale) 将B...

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运算方法:...

【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...

BigDecimal去除小数位

String cellValue = ""; double numericCellValue = cell.getNumericCellValue(); BigDecimal bd2...

java定义Bigdecimal类型

Java常用类型定义、转换及比较主要有以下三个方面: (一)Integer类型 1).定义 Integer a=new Integer(int value); Integer a=new Integer(String value); 2).转换 i.定义中就可以将int...

发表评论

访客

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