我们先看一段代码
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