C语言中的整型提升
整型提升的意义
C的整型运算总是以缺省整型类型的精度来进行的。
CPU的ALU内的操作数字长一般就是int的字节长度,为了使CPU中的ALU进行正常的计算,需要将字节长度短于int的char和short补全。
为了获得这个精度,表达式中的字符和短整型操作数在使用之前被转换为普通整型,这种转换称为整型提升。
如何进行整形提升?
以下代码的输出结果是什么呢?(操作系统为32位,int字节为4字节)
#include <stdio.h>
int 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(原)=-1
- signed char b = -1整型提升:11111111111111111111111111111111->10000000000000000000000000000000->10000000000000000000000000000001(原)=-1
- unsigned char c = -1整型提升:000000000000000000000000111111111(补=原)=255