问题描述:
请用 java 实现如下描述流程;你买了价值 1.1 元的东西,你给收银员 2.0 元钱,收银员找你 0.9 元?
答:你可能觉得这道题太 TM 简单了,上来就给出如下代码答案。
double total = 2.0;
double used = 1.1;
double result = total - used;
结果得到的结果是 0.8999999999999999,因为JAVA中的浮点型运算只得到近似值。所以这是一道经验踩坑题,为得到精确结果,需要调用JAVA在java.math 包中提供的 BigDecimal 处理
,因为 float 和 double 只能用来做科学计算或者工程计算,在商业计算中要用 java.math.BigDecimal,所以正确答案如下:
BigDecimal bd1 = new BigDecimal("2.0");
BigDecimal bd2 = new BigDecimal("1.1");
double result = (double) bd1.subtract(bd2);