整形提升定义
C语言表达式中字符和短整型操作数在使⽤之前被转换为普通整型,这种转换称为整型提升。
整型提升的意义
表达式的整型运算要在CPU的相应运算器件内执⾏,CPU内整型运算器(ALU)的操作数的字节⻓度⼀般就是int的字节⻓度,同时也是CPU的通⽤寄存器的⻓度。
因此,即使两个char类型的相加,在CPU执⾏时实际上也要先转换为CPU内整型操作数的标准⻓度。
通⽤CPU(general-purpose CPU)是难以直接实现两个8⽐特字节直接相加运算(虽然机器指令中可能有这种字节相加指令)。所以,表达式中各种⻓度可能⼩于int⻓度的整型值,都必须先转换为int或unsigned int,然后才能送⼊CPU去执⾏运算。
看的很晕吧,我也晕,概括一下(进行整型提升的都是那些大小不足一个 int(4个字节)的类型,比如:char、short 等,而这样的类型在计算过程中会造成精度不准确,因此需要发生整型提升,让他们占的空间更多一点,方便计算。也就是多补几个字节的空间给他们凑到4个字节大小)
如何进⾏整体提升呢?
- 有符号整数提升是按照变量的数据类型的符号位来提升的
- 符号整数提升,⾼位补0
代码演示1
char a,b,c;
...
a = b + c;
b和c的值被提升为普通整型,然后再执⾏加法运算。
加法运算完成之后,结果将被截断,然后再存储于a中。
代码演示(详解看注释)2
int main()
{
//char类型的取值范围是-128~127
//char 是占用1个字节的,1个字节是8个bit位
char c1 = 125;
//00000000000000000000000001111101
//发生截断
//01111101 -c1
//
char c2 = 10;
//00000000000000000000000000001010
//00001010 -c2
//开始整形提升
//00000000000000000000000001111101 -c1 - 有符号的char
//00000000000000000000000000001010 -c2 - 有符号的char
//00000000000000000000000010000111
//10000111 -c3
//
char c3 = c1 + c2;
//11111111111111111111111110000111//c3的整形提升然后取反+1得原码
//10000000000000000000000001111000
//10000000000000000000000001111001 //原码
//-121
printf("%d\n", c3);//-121
printf("%d\n", c1+c2);
//00000000000000000000000001111101
//00000000000000000000000000001010
//00000000000000000000000010000111 c1+c2
//%d 是打印有符号的整数
return 0;
}
代码演示(详解看注释)3
int main()
{
char a = 20;
//00000000000000000000000000010100
char b = 10;
//00000000000000000000000000001010
char c = a + b;
//00000000000000000000000000010100
//00000000000000000000000000001010
//00000000000000000000000000011110
//截断 char c - 0001 1110
//整形提升后原码
//00000000000000000000000000011110
printf("%d\n", a + b);
printf("%d\n", c);
system("pause");
return 0;
}
总结
c语言中只要存在表达式运算,就可能会发生整形提升,若A为char型,表达式 +c ,就会发生提升,所以 sizeof(+c) 是4个字节。同理sizeof(-c) 是4个字节,但是 sizeof© ,就是1个字节。
以上就是本篇博客的全部内容啦,欢迎大家指导!一起进步!