Java中浮点数为什么不精确的?

我们先看一段代码我们预想的结果是:事实上运算结果为:为什么会出现与我们所想的不一样呢?因为在计算机中,使用的是二进制进行运算的。 程序中,都是把十进制转换二进制,在进行运算的。浮点型计算的表达:那算机内部具体是怎么表示的呢?计算机不可能提供无限的空间让程序去存储这些二进制小数。它需要规定长度, 在Java 中, 提供了两种方式: float 和double , 分别是32位和64位。例如:有个浮点型double a = 0.1, double b =0.2,a+b=?;0.1是一个十进制的
摘要由CSDN通过智能技术生成

我们先看一段代码

  public static void main(String[] args) {
       System.out.println(0.1 + 0.2);
       System.out.println(0.2 - 0.1);
       System.out.println(0.1 * 0.2);
       System.out.println(0.2 / 0.1);
       
       System.out.println(0.3 - 0.1);
       System.out.println(0.3 / 0.1);


 }

我们预想的结果是:

   0.3
   0.1
   0.02
   2.0


   0.2
   3.0

事实上运算结果为:

   0.30000000000000004
   0.1
   0.020000000000000004
   2.0


   0.19999999999999998
   2.9999999999999996

为什么会出现与我们所想的不一样呢?

因为在计算机中,使用的是二进制进行运算的。 程序中,都是把十进制转换二进制,在进行运算的。

浮点型计算的表达:

那算机内部具体是怎么表示的呢?

计算机不可能提供无限的空间让程序去存储这些二进制小数。

它需要规定长度, 在Java 中, 提供了两种方式: float 和double , 分别是32位和64位。

例如:有个浮点型double a

  • 9
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值