原码反码补码:
正数的原码反码补码相同。
负数的原码:例:当把a=-1定义为整型时
-1的原码为10000000 00000000 00000000 00000001(总共是32位4个字节,因为整型的长度是4个字节32位。最高位为符号位,1为负数,0为正数)
-1的反码为11111111 11111111 11111111 11111110(原码符号位不变,其他位全部置为原码的相反位,即为反码)
-1的补码为11111111 11111111 11111111 11111111(反码+1,即为补码)
~按位取反:
按位取反即把二进制数全部位取反。
例:把a=0定义为整型时
a的二进制数表示为:00000000 00000000 00000000 00000000(总共是32位4个字节,因为整型的长度是4个字节32位。)
~a=11111111 11111111 11111111 11111111
但若使用printf函数输出~a的结果的话,结果为多少呢?
int main()
{
int a = 0;
printf("%d\n", ~a);
return 0;
}
执行结果为:
执行结果是-1而不是2^32,原因是在数据存储单元中,数据是以补码的形式存在的。而按位取反的操作是在数据存储单元中执行的,所以所得的结果亦为补码。而printf函数输出的结果是原码转化为十进制数,所以输出之前还得把补码转化成原码。
~a的补码为:11111111 11111111 11111111 11111111
~a的反码为:11111111 11111111 11111111 11111110(补码-1,即为反码)
~a的原码为:10000000 00000000 00000000 00000001(反码符号位保持不变,除符号位以外的全部位取反,即为原码)
所以输出~a的结果为-1。
~ 按位取反和反码的区别:
按位取反不考虑符号位,所有位都取相反;
反码需要保留符号位,除符号位以外所有位取反。