A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 孔斌 中级黑马   /  2013-1-28 12:26  /  1245 人查看  /  3 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

  1. public class Test1 {

  2.         /**
  3.          * 有关数值运算的问题
  4.          */
  5.         public static void main(String args[]){
  6.                 System.out.println(2.00 - 0.10);//1.9
  7.                 System.out.println(2.00 - 1.10);//0.8999999999999999
  8.         }
  9. }
复制代码
为啥结果是这样的呢?

评分

参与人数 1技术分 +1 收起 理由
冯海霞 + 1

查看全部评分

3 个回复

倒序浏览
1.1这个数字不能被精确表示
为一个double,因此它被表示为最接近它的double 值,该程序从2 中减去的就是这个值,
但这个计算的结果并不是最接近0.9 的double值。
因为Java表示浮点数是使用二进制标示的,而0.1即1/10是无法用二进制来表示的:
2进制表示小数的时候只能够表示能够用1/(2^n)的和的任意组合
http://leowzy.iteye.com/blog/792509

评分

参与人数 1技术分 +1 收起 理由
冯海霞 + 1 很给力!

查看全部评分

回复 使用道具 举报
public class Test1 {


        /**

         * 有关数值运算的问题

         */

        public static void main(String args[]){

                System.out.println(2.00 - 0.10);//1.9 //2.00和0.10并不是2和0.1而是很接近他们的数字,下面也一样

                System.out.println(2.00 - 1.10);//0.8999999999999999

        }

}
回复 使用道具 举报
double类型是这样的。。它默认是double类型  而double是有精确度的  不能保证准确的其实你自己看一下double类型的api文档就明白了出现这种问题的原因是浮点数值是采用二进制系统表示的,而在系统中无法精确的表示分数1/10。需要在计算中不含有任何舍入误差,就应该使用BigDecimal类。2.00是double,1.10是double,double减double还是double,double是浮点数,精度其实是有限的,最后输出就变这鸟样了
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马