其他分享
首页 > 其他分享> > 位运算 - 非

位运算 - 非

作者:互联网

在位运算中,非运算最特殊,所以这里写篇文章...

在此之前我们需要明白两个计算机常识:

一、在计算机中,机器数分为符号位数值位。

  • 符号位:只有一位,用 '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