在汇编中对数字的存储是有分有符号和无符号的,C语言同样如此,负数就是正数取反+1, 总结如下
负数 | 二进制 | 寄存器AL | 十六进制 |
0-1 | ...11111111 | 1111 1111 | 0xFF |
0-2 | ...11111110 | 1111 1110 | 0xFE |
| 左边在不停的借位 | 寄存器只保存8bit |
|
测试代码
#include <stdio.h>
int main()
{
char c = -5;
short s = 6;
int i = -7;
// 1111 1011 & 1000 0000 =1000 0000
printf("%d\n", ( (c & 0x80) != 0 ));
// 0000 0000 0000 0110 & 1000 0000 0000 0000 =0
printf("%d\n", ( (s & 0x8000) != 0 ));
// 1111 1111 1111 1111 1111 1111 1111 1001 & 1000 0000 0000 0000 0000 0000 0000 0000
printf("%d\n", ( (i & 0x80000000) != 0 ));
return 0;
}
测试结果
在C语言中,只有整数类型能够声明unsigned变量,并且当无符号和有符号混合运算,会先统一成有符号数,再转换成无符号数后计算,最后结果是无符号数,所以在平时写代码中一定要区分有无符号。如以下测试代码中,i 永远不能变成负数,导致无限循环
测试代码
#include <stdio.h>
int main()
{
unsigned int i = 0;
for(i=9; i>=0; i--)
{
printf("i = %u\n", i);
}
return 0;
}
测试结果: