1.题目一:
#include <stdio.h>
int main()
{
char a = -128;
printf("%u\n",a);
return 0;
}
%u 是打印无符号整型
解题逻辑:
1. 原反补互换,截断
-128
原码:10000000…10000000
补码:11111111…10000000
(char类型占 1 个字节,8 个bit位)截断:10000000
2.整型提升:
char 默认 signed char 所以高位补符号位:11111111…10000000
3.%u打印的结果:
%u 是打印无符号整型,那么补码 11111111…10000000 中第一个 1 不是符号位,此时原码与补码相同,打印出来的就是二进制11111111…10000000所代表的十进制数:4294967168
2.题目二:
#include <stdio.h>
int main()
{
char a = 128;
printf("%u\n",a);
return 0;
}
char 类型的存储范围是 -128~127 那么存了 128怎么打印?
必须将 128从低位截断
截断后是 10000000
整型提升:11111111…10000000
(整型提升时,只与变量类型有关,有符号的往高位加符号位,无符号的高位补 0!!)
所以下面的步骤和上一题一样
结果也是4294967168