文档章节

double类型转BigDecimal类型精度丢失

baibuxiha
 baibuxiha
发布于 2017/05/12 20:54
字数 282
阅读 124
收藏 1

在项目中,一般遇到关于金钱方面的,我们会使用BigDecimal类型存储金额,但是通常情况下金额都是double类型,需要转换为BigDecimal类型。但是使用不当,会造成金额错误。

##问题重现

public class TestBigDecimal {
	public static void main(String[] args) {
            double d = 201111.05;
           System.out.println(d);//201111.05
           BigDecimal decimal = new BigDecimal(d);
           System.out.println(decimal);//201111.0499999999883584678173065185546875
           System.out.println(decimal.setScale(1, RoundingMode.HALF_UP));//201111.0
	}
}
201111.05
201111.0499999999883584678173065185546875
201111.0

从上面代码运行结果可以看出,double类型的变量转换成BigDecimal类型的时候数值发生了改变, 精度丢失了,因此不能使用此构造方法进行转换。 ##解决方法

import java.math.BigDecimal;

public class TestBigDecimal {

	public static void main(String[] args) {
            double d = 201111.05;
            System.out.println(new BigDecimal(Double.toString(d)));//201111.05
            System.out.println(BigDecimal.valueOf(d));//201111.05
	}
}
201111.05
201111.05
BigDecimal使用参数为String类型的构造器或者使用BigDecimal.valueOf()方法替代。BigDecimal.valueOf()方法内部也是使用new BigDecimal(String value)类型构造器进行实例化。
   public static BigDecimal valueOf(double val) {
        // Reminder: a zero double returns '0.0', so we cannot fastpath
        // to use the constant ZERO.  This might be important enough to
        // justify a factory approach, a cache, or a few private
        // constants, later.
        return new BigDecimal(Double.toString(val));
    }

© 著作权归作者所有

共有 人打赏支持
baibuxiha
粉丝 6
博文 67
码字总数 33393
作品 0
金融系统中正确的金额计算及存储方式

image 昨天微信群里在讨论金额计算及存储的话题,今天特来结贴一下。 经典的精度丢失问题 Java中的类型float、double用来做计算会有精度丢失问题,下面来看下面的示例。 上面的程序输出结果是...

架构之路
2017/12/01
0
0
Java中解决浮点数精度的问题

问题描述 在项目中用Java做浮点数计算时,发现对于4.015*100这样的计算,结果不是预料中的401.5,而是401.49999999999994。如此长的位数,对于显示来说很不友好。 问题原因:浮点数表示 查阅...

GreenDay
2016/09/30
81
0
Java中浮点型数据Float和Double进行精确计算的问题

一、浮点计算中发生精度丢失 大概很多有编程经验的朋友都对这个问题不陌生了:无论你使用的是什么编程语言,在使用浮点型数据进行精确计算时,你都有可能遇到计算结果出错的情况。来看下面的...

Junn
2013/06/10
0
1
java中浮点型数据的大小比较问题

一. 精度 举例:double result = 1.0 - 0.9; 这个结果不用说了吧,都知道了,0.09999999999999998 float和double类型主要是为了科学计算和工程计算而设计的。他们执行二进制浮点运算,这是为...

wangtx
2016/12/28
61
0
转:BigDecimal 使用方法详解

转贴:http://zhangyinhu8680.iteye.com/blog/1536397 BigDecimal 由任意精度的整数非标度值 和 32 位的整数标度 (scale) 组成。如果为零或正数,则标度是小数点后的位数。如果为负数,则将该...

克温s
2016/05/13
78
0

没有更多内容

加载失败,请刷新页面

加载更多

原型模式

1、原型模式-定义 用原型实例指定创建对象的种类,并且通过拷贝这些原型创建新的对象 克隆(浅度克隆->拷贝值类型或者引用,深度克隆->创建新的对象,开辟新的内存) 例如客户端知道抽象Pro...

阿元
今天
32
0
awk命令扩展使用操作

awk 中使用外部shell变量 示例1 [root@centos01 t1022]# A=888[root@centos01 t1022]# echo "" | awk -v GET_A=$A '{print GET_A}'888[root@centos01 t1022]# echo "aaaaaaaaaaaaa" | aw......

野雪球
今天
29
0
深入解析MySQL视图VIEW

Q:什么是视图?视图是干什么用的? A:视图(view)是一种虚拟存在的表,是一个逻辑表,本身并不包含数据。作为一个select语句保存在数据字典中的。   通过视图,可以展现基表的部分数据;...

IT--小哥
今天
38
0
虚拟机学习之二:垃圾收集器和内存分配策略

1.对象是否可回收 1.1引用计数算法 引用计数算法:给对象中添加一个引用计数器,每当有一个地方引用它时,计数器值就加1;当引用失效时,计数器值就减1;任何时候计数器值为0的对象就是不可能...

贾峰uk
今天
25
0
smart-doc功能使用介绍

smart-doc从8月份底开始开源发布到目前为止已经迭代了几个版本。在这里非常感谢那些敢于用smart-doc去做尝试并积极提出建议的社区用户。因此决定在本博客中重要说明下smart-doc的功能,包括使...

上官胡闹
昨天
38
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部