网站首页 > 精选教程 正文
先用简单的代码展示一下
Java代码:
上面的代码主要的区别在于
初始化BigDecimal时形参是double、String和float的区别
从上面可以看到,当double 和 float 时,实际保存的值并不是是准确的0.99,这是为什么呢
大致的原因是:
BigDecimal(double val)将会把double型二进制浮点型值精确的转换成十进制的BigDecimal。
你可能认为java中用new BigDecimal(0.1)创建的BigDecimal应该等于0.1(一个是1的无精度的值,一个是有精度的值),但实际上精确的是等于
0.1000000000000000055511151231257827021181583404541015625。这是因为0.1不能被double精确的表示(下面大概描述一下原理)。因此,传入构造函数的值不是精确的等于0.1。
对与float也是同样的道理。首先此函数会自动进行精度扩展,将float类型的0.99转成double类型的,因为0.99本身就是无法用二进制表示的,也就说无论你的精度是多少位,都无法用二进制来精确表示0.99,或者你用二乘来判断(0.99*2=1.98 0.98*2=1.960.96*2=1.92 。。。永远无法得到一个整数)。这就是二进制计算机的缺点,就如同十进制也也无法表示1/3,1/6一样。
所以在0.99f转成double时,进行了精度扩展,变成了0.9900000095367432,而接着转成字符串,最后转成BigDecimal.
总结:
所以在当遇到需要涉及到精确计算的时候,如上面代码所示,要注意该构造函数是一个精确的转换,它无法得到与先调用Double.toString(double)方法将double转换成String,再使用BigDecimal(String)构造函数一样的结果。如果要达到这种结果,
应该使用new BigDecimal(Stringvalue) 或 BigDecimal.valueof( double value)
顺便问一下,做过支付相关的同学,这个支付金额一般保留几位数子,如何处理的,可以说下吗,谢谢了
猜你喜欢
- 2025-04-01 吊打面试官(九)--Java语言Object类一文全掌握
- 2025-04-01 Java面向对象编程:从继承困惑到多态应用的实战解析
- 2025-04-01 Qt数字转QString保留小数点位数的方法
- 2025-04-01 long和double类型操作的非原子性探究
- 2025-04-01 Java泛型全方位剖析:从入门到精通的完整指南(上篇)
- 2025-04-01 java 基础调试技巧与控制台输入输出
- 2025-04-01 C语言字符串操作总结大全(超详细)
- 2025-04-01 Java 8:CompletableFuture终极指南
- 2025-04-01 Java中的String、StringBuilder和StringBuffer的区别及适用场景
- 2025-04-01 物理老师教你学Java语言(下篇)(物理专业学编程)
你 发表评论:
欢迎- 最近发表
- 标签列表
-
- nginx反向代理 (57)
- nginx日志 (56)
- nginx限制ip访问 (62)
- mac安装nginx (55)
- java和mysql (59)
- java中final (62)
- win10安装java (72)
- java启动参数 (64)
- java链表反转 (64)
- 字符串反转java (72)
- java逻辑运算符 (59)
- java 请求url (65)
- java信号量 (57)
- java定义枚举 (59)
- java字符串压缩 (56)
- java中的反射 (59)
- java 三维数组 (55)
- java插入排序 (68)
- java线程的状态 (62)
- java异步调用 (55)
- java中的异常处理 (62)
- java锁机制 (54)
- java静态内部类 (55)
- java怎么添加图片 (60)
- java 权限框架 (55)
本文暂时没有评论,来添加一个吧(●'◡'●)