单目操作符之“~”(按位取反):
一、代码:
#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
int main()
{
int a = 0;
int b = ~a;
printf("%d\n", b);
return 0;
}
二、运行结果截图:
三、代码及结果分析:
(1)、按位取反(~)
单目操作符中的“~”被称为按位取反,位指的是二进制位,而二进制位是由0和1组成的序列,所以取反指的是原来是0则取反为1,同理,原来是1则取反为0。
例如:
现在有一个二进制序列为10100011,
按位取反的二进制序列为01011100。
int类型的大小为4个字节,即32个bit位,也就是32个二进制位。
int a=0,则a的二进制序列为00000000000000000000000000000000(32个0),
#include <stdio.h>
int main()
{
int a = 0; //int类型,4个字节,32个bit位
//a=0,0的二进制序列为:00000000000000000000000000000000(32个0)
int b = ~a; //b的值等于对a按位取反
//对a取反之后的二进制序列:11111111111111111111111111111111(32个1)
printf("%d\n", b); // 使用的、打印的是这个数的原码,打印结果是-1
return 0;
}
(2)、原码、反码、补码
//只要是整数,内存中存储的都是二进制的补码
//正数的原码、反码、补码均相同
//a=0的二进制序列:00000000000000000000000000000000(32个0)
//取反之后b的二进制序列:11111111111111111111111111111111(32个1)
//b是有符号的整型,有符号的整型(int)的二进制序列的最高位是符号位,最高位如果为1,表示它是个负数;
//负数的原码--->反码--->补码的过程如下:
//原码符号位(最高位)不变,其他位按位取反得到反码;反码+1得到补码
printf("%d\n",b)使用的是b得原码
从补码到原码的逆推过程如下:
//11111111111111111111111111111111(补码)
//11111111111111111111111111111110(反码):补码-1得到反码
//10000000000000000000000000000001(原码):反码符号位(最高位)不变,其他位按位取反得到原码