1、基础知识
(1)负数在计算机中是以补码的形式存储的;
(2)有符号数的最高位为1表示为负数,为0表示正数;
(3)反码:等于原码除过符号位,其余位取反;
(4)补码:等于反码加1。
2、以-62为例说明
下面以一个-62为例推导在计算机中的存储的数;
62对应的16进制为0x3E,转换成二进制 0011 1110,那么-62的:
原码为1011 1110,
反码为1100 0001,
补码为1100 0010,即就是0xC2,也就是-62在计算机中是以C2的形式存储的。
3、代码实现补码转换成原码
#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;
}