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 浮点数在实际应用场景中踩坑题目解析

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 在C语言中,五种基本数据类型存储空间长度的排列顺序是: A)char B)char=int<=float C)ch...
    夏天再来阅读 8,755评论 0 2
  • 此篇文章搬运于:http://blog.csdn.net/aya19880214/article/details/...
    myleosu阅读 7,044评论 0 0
  • K# Java核心技术卷一 逐一声明每一个变量可以提高程序的可读性。 在Java中,变量的声明尽可能地靠近变量第一...
    兰陵忧患生阅读 3,184评论 0 1
  • 同样是做梦,我室友,梦到了邂逅李佩斯,还相爱了,而我,梦到了一个凶案现场,目睹了凶手怼死一屋子的人之后,我...
    喃惜阅读 1,326评论 0 0
  • hello,大家好,我是一名汤圆新人,这篇文希望大家能喜欢,关于这篇《当安琪拉恋上李白》,在汤圆上也有,当然也是我...
    Yoky凌九烟阅读 5,386评论 0 5