黑马程序员技术交流社区

标题: 数字计算 [打印本页]

作者: fengche    时间: 2013-10-16 11:41
标题: 数字计算
本帖最后由 fengche 于 2013-10-17 13:25 编辑

public class Change{
        public static void main(String args[]){
                System.out.println(2.00 - 1.10);
        }
}
打印的是0.8999999999999999
从网上看到的 求黑马大神解释?

作者: loading……99.9    时间: 2013-10-16 11:56
并不是所有的浮点数都能准确的用二进制表示出来。使用jdk1.5或更高版本的使用System.out.printf("%.2f%n", 2.0 - 1.1);这个可以打印出来。
作者: 做只会飞的鱼    时间: 2013-10-16 11:57
菜鸟一个...
因为是浮点运算,浮点运算采用补码规则,得到的结果不精确
作者: 花生壳    时间: 2013-10-16 12:22
float和double只能用来做科学计算或者是工程计算,在商业计算中我们要用java.math.BigDecimal。float和double有默认的精确位数。
作者: ☆╰學不会☆╮    时间: 2013-10-16 13:21
LZ没有定义数据类型 如果带小数点 默认的都是double双精度浮点型。
double i = 2.00;
double j = 1.10;
System.out.println(i-j);
至于结果 出现这种问题的原因是浮点数值是采用二进制系统表示的,而在系统中无法精确的表示分数1/10
有的时候损失点精度也是正常的 也不必过于纠结结果了。
如果真的想整明白,那就去好好的学学java编程的底层代码吧。
作者: 李江    时间: 2013-10-16 18:52
问题解决后,麻烦楼主把帖子状态改为提问结束...谢谢配合工作...




欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2