(1)负数在计算机中是以补码的形式存储的; (2)有符号数的最高位为1表示为负数,为0表示正数; (3)反码:等于原码除过符号位,其余位取反; (4)补码:等于反码加1。
下面以一个-62为例推导在计算机中的存储的数; 62对应的16进制为0x3E,转换成二进制 0011 1110,那么-62的: 原码为1011 1110, 反码为1100 0001, 补码为1100 0010,即就是0xC2,也就是-62在计算机中是以C2的形式存储的。
#include <stdio.h>
int main(void) {
unsigned char buma=0xc2;
unsigned char fanma=0;
signed char yuanma=0;
unsigned char index,temp=0;
printf("buma=%x\r\n",buma);
fanma=buma-1;
printf("fanma=%x\r\n",fanma);
for(index=0;index<7;index++)
{
temp=fanma>>index;
temp=~temp;
temp&=0x01;
temp=temp<<index;
yuanma+=temp;
}
if(fanma&0x80)
{
yuanma=-yuanma;
}
printf("yuanma=%d\r\n",yuanma);
return 0;
}
推荐阅读: