原码
正数的原码就是将正数转化为二进制,负数的原码就是将绝对值转化为二进制并在高位补1。
例如:int 3,在32位机器上占4个字节,原码:00000000 00000000 00000000 00000011;
int -3,原码:10000000 00000000 00000000 00000011。
但在原码中,0的表示不唯一,且正负数相加后无法区分正负性,需要将值取绝对值后运算,运算结果符号由绝对值大的一方决定。
反码(中间码)
正数的反码等同于原码,负数的反码等于
符号位之外
的所有位取反。
int 3,反码:00000000 00000000 00000000 00000011;
int -3,反码:11111111 11111111 11111111 11111100。
但0的表示依旧不唯一。
补码
正数的补码等于原码,负数的补码等于反码最低位加1。
int 3,补码:00000000 00000000 00000000 00000011;
int -3,补码:11111111 11111111 111111111 11111101。
补码求原码:对补码再求补即可(求反加1)
总结
正数的原码反码补码相等;
负数的原码等于正数原码最高位加1,反码等于负数原码符号位以外的位求反,补码等于负数反码最低位加1
若负数之和为正数或正数之和为负数则说明运算结果溢出。