C的整型运算总是以缺省整型类型的精度来进行的。
CPU的ALU内的操作数字长一般就是int的字节长度,为了使CPU中的ALU进行正常的计算,需要将字节长度短于int的char和short补全。
为了获得这个精度,表达式中的字符和短整型操作数在使用之前被转换为普通整型,这种转换称为整型提升。
以下代码的输出结果是什么呢?(操作系统为32位,int字节为4字节)
#includeint main() { char a = -1; signed char b = -1; unsigned char c = -1; printf("a=%d, b=%d, c=%d", a, b, c); return 0; }
char类型-1的原码:10000001
char类型-1的反码:111111110
char类型-1的补码:111111111
负数的整型提升:高位补充符号位,即补充1正数的整型提升:高位补充符号位,即补充0
分析例子:
char a = -1整型提升:11111111111111111111111111111111->10000000000000000000000000000000->10000000000000000000000000000001(原)=-1signed char b = -1整型提升:11111111111111111111111111111111->10000000000000000000000000000000->10000000000000000000000000000001(原)=-1unsigned char c = -1整型提升:000000000000000000000000111111111(补=原)=255



