昨天笔试遇到一个选择题,题目是以下程序的输出结果
#include <iostream>
#include <stdlib.h>
using namespace std;
int main()
{
char c = -127;
c -= 1;
printf("%d\n",c);
c -= 1;
printf("%d\n",c);
c = 127;
c += 1;
printf("%d\n",c);
c += 1;
printf("%d\n",c);
system("pause");
return 0;
}
这里适合结合我以前转发的一篇原码、反码、补码原理讲解一起进行解析
[-127] = [1111 1111]原 = [1000 0000]反 = [1000 0001]补
[-1] = [1000 0001]原 = [1111 1110]反 = [1111 1111]补
c=-127; c-=1;
[1000 0001] + [1111 1111] = 1 [1000 0000] 为-128的补码
c=-128; c-=1;
[1000 0000] + [1111 1111] = 1 [0111 1111] 为127的补码
c=127; c+=1;
[0111 1111] + [0000 0001] = [1000 0000] 为-128的补码
c=-128; c+=1;
[1000 0000] + [0000 0001] = [1000 0001] 为-127的补码