位运算 - 非
作者:互联网
在位运算中,非运算最特殊,所以这里写篇文章...
在此之前我们需要明白两个计算机常识:
一、在计算机中,机器数分为符号位和数值位。
- 符号位:只有一位,用 '0' 表示正数 '1' 表示负数,用最高位(即最左边的位置数字来表示)。
- 数值位:如整数 int 其中 2^32-1 位用来表示数值。
二、数字以补码的形式存储在计算机中。
- 原码 就是正常二进制。
- 补码 计算机中只能加,不能减,所以用补码来进行减
- 反码 原码转换成补码的中间过程产物
补码由原码除符号位,每位取反末位加 1 来表示
数字 5
原码: 0101 符号位为 0 数值位为 101
补码: 0010 符号位为 0 数值位为 010
非 ,就是一个数的二进制 0 变 1 ,1 变 0,
符号位同时改变!!!!
举例 5
5 在计算机中是补码形式为
5: 0010 符号位 为 0 数值位为 010
取非
~5: 1101 符号位为 1 数值位为 101
是 -6 的补码形式。
把 1101 看成补码表示的数字是 -6(原码变反码的逆过程:1101 减去1 除符号位外每位取反)。
标签:运算,符号,补码,数值,1101,原码,位为 来源: https://blog.csdn.net/m0_53824537/article/details/123068036