Java 浮点数相关

问:请用 java 实现如下描述流程;你买了价值 1.1 元的东西,你给收银员 2.0 元钱,收银员找你 0.9 元?

答:

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");
BigDecimal result =  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 两次都进行字符串拼接操作。

本文参考自 Java 浮点数在实际应用场景中踩坑题目解析

你可能感兴趣的:(Java 浮点数相关)