Java 浮点数在实际应用场景中踩坑题目解析

问:请用 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);

问:下面两行语句分别输出什么?

String str1 = 'a' + 3 + "Hello";
String str2 = "Hello" + 'a' + 3;

答:如上 str1 为 100Hello,str2 为 Helloa3。因为 java 中 char 字符型存放字符常量,底层使用 16 位无符号整型表示,所以对于 str1 运算时 'a' + 3 会被转换成 int 运算,然后进行字符串拼接;而 str2 两次都进行字符串拼接操作。

猜你喜欢

转载自blog.csdn.net/lipr86/article/details/83061305