原码,反码,补码
整数的二进制有三种表示形式:原码,反码,补码
三种表示形式都有符号位和数值位,符号位用0表示“正”,1表示“负”,而数值位正数的原、反、补都相同,
负数的原码,负数的反码就是在原码基础上符号位不变,数值位按位取反,负数反码+1就是补码
int a=20
00000000000000000000000000010100原码
00000000000000000000000000010100反码
00000000000000000000000000010100补码
int b=-20
10000000000000000000000000010100原码
111111111111111111111111111111111111101011反码
111111111111111111111111111111111111101100补码
注:对于整形来说:数据存放在内存中的其实是补码
int a=1;
补码:00000000000000000000000000000001
int b=-1;
原码:10000000000000000000000000000001
反码:1111111111111111111111111111111111111111110
补码:1111111111111111111111111111111111111111111
int c=a+b
c的补码:
1
00000000000000000000000000000000(这里是33位,但是只能存储32位,所以高位1,丢弃)
则c的补码:00000000000000000000000000000000
所以c的原码:00000000000000000000000000000000