《一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码》,点击传送门,即可获取!
1.我们先看一个例子
可以看到在Java中进行浮点数运算的时候,会出现丢失精度的问题。那么我们如果在进行商品价格计算的时候,就会出现问题。很有可能造成我们手中有0.06元,却无法购买一个0.05元和一个0.01元的商品。
因为如上所示,他们两个的总和为0.060000000000000005。这无疑是一个很严重的问题,尤其是当电商网站的并发量上去的时候,出现的问题将是巨大的。可能会导致无法下单,或者对账出现问题。所以接下来我们就可以使用Java中的BigDecimal类来解决这类问题。
2.BigDecimal中的一些方法
| 构造器 | 描述 |
| — | — |
| BigDecimal(int) | 创建一个具有参数所指定整数值的对象。 |
| BigDecimal(double) | 创建一个具有参数所指定双精度值的对象。 |
| BigDecimal(long) | 创建一个具有参数所指定长整数值的对象。 |
| BigDecimal(String) | 创建一个具有参数所指定以字符串表示的数值的对象。 |
| 方法 | 描述 |
| — | — |
| add(BigDecimal) | BigDecimal对象中的值相加,然后返回这个对象。 |
| subtract(BigDecimal) | BigDecimal对象中的值相减,然后返回这个对象。 |
| multiply(BigDecimal) | BigDecimal对象中的值相乘,然后返回这个对象。 |
| divide(BigDecimal) | BigDecimal对象中的值相除,然后返回这个对象。 |
| toString() | 将BigDecimal对象的数值转换成字符串。 |
| doubleValue() | 将BigDecimal对象中的值以双精度数返回。 |
| floatValue() | 将BigDecimal对象中的值以单精度数返回。 |
| longValue() | 将BigDecimal对象中的值以长整数返回。 |
| intValue() | 将BigDecimal对象中的值以整数返回。 |
3.值得注意的是如果要想无精度丢失的情况下计算结果,那么需要把double,float类型的参数转化为String类型的。并且使用BigDecimal(String)这个构造方法进行构造,去获取结果。不然还是没有效果。
(1)
(2)
4.在一般开发过程中,我们数据库中存储的数据都是float和double类型的。在进行拿来拿去运算的时候还需要不断的转化,这样十分的不方便。这里我写了一个工具类,以后可以直接使用。
public class BigDecimalUtil {
private BigDecimalUtil() {
}
public static BigDecimal add(double v1, double v2) {
// v1 + v2
BigDecimal b1 = new BigDecimal(Double.toString(v1));
BigDecimal b2 = new BigDecimal(Double.toString(v2));
return b1.add(b2);
}
public static BigDecimal sub(double v1, double v2) {
//v1-v2
BigDecimal b1 = new BigDecimal(Double.toString(v1));
BigDecimal b2 = new BigDecimal(Double.toString(v2));
写在最后
可能有人会问我为什么愿意去花时间帮助大家实现求职梦想,因为我一直坚信时间是可以复制的。我牺牲了自己的大概十个小时写了这片文章,换来的是成千上万的求职者节约几天甚至几周时间浪费在无用的资源上。
上面的这些(算法与数据结构)+(Java多线程学习手册)+(计算机网络顶级教程)等学习资源
《一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码》,点击传送门,即可获取!
+(Java多线程学习手册)+(计算机网络顶级教程)等学习资源
《一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码》,点击传送门,即可获取!