JAVA按位取反运算

按位取反是对补码进行运算,当运算完后得到是补码,然后再将补码变回原码。

例题

1.求~9的结果是什么

解:9的二进制数表示 0000 1001
9的原码 0000 1001
9的反码 0000 1001 (原码取反码,最高位符号位不变)
9的补码 0000 1001
按位取反操作 1111 0110(补码取反,最高位符号位也变
变为补码先减一 1111 0101(得通过补码到反码)
再取反 1000 1010 (-10)(反码取反得到原码,最高位符号位不变

2.求~-9的结果

-9的二进制数表示 1000 1001
-9的原码 1000 1001
-9的反码 1111 0110
-9的补码 1111 0111
按位取反操作 0000 1000 (得到补码,是正数)
变为原码 0000 1000 (8) 因为正数的补码、反码、原码都是一个样。

原文

https://blog.csdn.net/mx0418/article/details/82894579

你可能感兴趣的:(JAVA按位取反运算)