在Java中,如果一个正数与其相反数进行二进制并操作,其结果的二进制是:该正数二进制最右边值为1的比特位上值是1,其它的比特位值是0
在说明这个结论之前,首先要知道,在Java中,整数数值在底层是由补码表示的。对于正数而言,它的补码就是它的原码。而对于负数而言,其补码是其相反数(正数)的反码在加1。
举例:
5的二进制为: 0000 1001
-5的二进制为:1111 0111
则5 & -5 = 5 & (~5 + 1)= 0000 0001 & (1111 0110 + 1) = 0000 0001
对于二进制而言,如果让它加上1,会使得这个二进制的最右边值为0的比特位的值变成1。