一。System.out.println(2.0-1.1)结果不是0.9
因为二进制中无法精确表示0.9,0.9用二进制表示是一个无限循环小数(0.11100110011001100....)。再将它转换为十进制后变成了(0.899999999999999999999)。
二。整数被0除会产生一个异常,而浮点数被0除将会得到无穷大(Infinity)或NaN的结果。
三。通过运用2的幂次方的&运算可以将其他位屏蔽掉:
int fourthBigFromRight = (n & 8) / 8;
//或者用 int fourthBigFromRight = (n & (1 << 3)) >> 3;
if(fourthBigFromRight == 1)
n的第四位为1;