在Java中,如果一个正数与其相反数进行二进制并操作,其结果的二进制是:该正数二进制最右边值为1的比特位上值是1,其它的比特位值是0

在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。

Guess you like

Origin blog.csdn.net/weixin_43394832/article/details/121187032