我也只能确定0.1不能被精确显示,具体该如何解这样的题呢?
其实我进一步思考了。我以为就看尾数是不是5。比如0.5、0.05。因为2的-x次方的尾数都是5。是5就能精确显示,不是就不能。但是后来发现
说明不能只靠最终结果来判断...............那该怎么判断啊?
问题补充:我知道有BigDecimal这个类,我只可以用这个类避免精度问题。
但是我的问题就是如果做笔试题的时候,遇到这种挫科的问题(如第二幅图所示,刚刚图错了,不好意思哈~~呵呵),该如何找到正确的选项?
对于float 和 double, 建议用BigDecimal进行运算。
import java.math.BigDecimal;
public class DoubleTest {
public static void main(String[] args) {
double d = 3.0d;
double f = 2.1d;
BigDecimal bd1 = new BigDecimal(Double.toString(d));
BigDecimal bd2 = new BigDecimal(Double.toString(f));
System.out.println("result=" + bd1.subtract(bd2));
}
}
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。