浮点类型的种种悬疑
浮点类型只是近似的存储,这很显而易见,因为在计算机内部是使用二进制来存储数值的,而对于0.3333之类的奇数小数就没办法存储,因此采用的是一种近似值的方式进行存储的,所以就会造成一个误差:下面代码将输出false,因为对于浮点数运算会存在误差:
double x = 0.1, y = 0.2, z = 0.3;
System.out.println(x+y==z);
//真正的0.1+0.2等于0.3000000004左右,后面会携带偏差值
System.out.println(x+y);
++i和i++解析(目前我看到的最好理解的讲解方式)
首先,我们知道i++和i++的一个明显的区别就是:前者先i先进行其他运算操作再自增,后者i先自增再进行其他运算操作。那么如果对于下面这种情况呢?
int i = 1;
int y = 2;
i = i++;
y = ++y;
System.out.println(i);
System.out.println(j);
首先说一下他们的结果分别为:i=1,j=3; 我们可以将它改变成一个容易看懂的操作: