关于BigDecimal精度部分总结

关于BigDecimal精度部分总结

BigDecimal类概述

Java中提供了大数字(超过16位有效位)的操作类,即java.math.BigInteger类和java.math.BigDecimal类,用高精度计算。其中BigInteger类是针对大整数的处理类,BigDecimal 类则是针对大小数的处理类。
在商业计算中,对数字精度要求较高,必须使用 BigInteger 类和 BigDecimal 类,它支持任何精度的定点数,可以用它来精确计算货币值。
由于在运算的时候,float类型和double很容易丢失精度,所以一般不用来做计算货币。

由于浮点不精确,程序不太可能从 BigDecimal(double)构造函数中获取预期的值。

new BigDecimal(double)这个构造函数的结果可能有点不可预测。有人可能会假设在Java中编写的BigDecimal(0.1)会创建一个BigDecimal,他恰好是等于0.1(未缩放值为1,标度为1),但它实际上等于 0.1000000000000000055511151231257827021181583404541015625 。这是因为0.1不能精确的表示为double(或者,就此而言,作为任何有限长度的二进制分数)。因此,传递给构造函数的值并不完全等于0.1,尽管有外观。

相反。应该使用BigDecimal.valueOf,它使用封面下的字符串来消除浮点的舍入错误,或者使用String参数的构造函数。

double d = 1.1;
BigDecimal bd1 = new BigDecimal(d); //不合规; 见上面的评论
BigDecimal bd2 = new BigDecimal(1.1); //不合规; 同样的结果
double d = 1.1;
BigDecimal bd1 = BigDecimal.valueOf(d);
BigDecimal bd2 = new BigDecimal(“1.1”); //使用String构造函数将产生精确的值
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值