C整型提升机制
1.整型提升的意义
表达式的整型运算要在CPU的相应运算器件中执行,CPU内整型运算器(ALU)的操作数的字节长度一般就是int的字节长度,同时也是CPU的通用寄存器长度。
因此,即使两个char类型的相加,在CPU执行时实际上也要先转换为CPU内整型操作数的标准长度。
通用CPU是难以直接实现两个8比特字节直接相加运算,所以,表达式中各种长度可能小于int长度的整型值,都必须先转换为int或者unsigned int,然后才能送到CPU中去运算。
ps:整型打印显示的是原码,计算机中存储的是补码
2.实例
整型提升是按照变量的数据类型的符号位来提升
//负数的整形提升
char c1=-1; //变量中的二进制位(补码)只有8个比特位 //11111111 //因为char为有符号位的char,所以在整形提升的时候,,高位补充符号位,即为1,提升之后的效果是: 1111111111111111111111111111
//正数的整型提升
char c2=1; 变量c2的二进制位(补码)只有8个比特位 00000001 因为char为有符号的char 所以整型提升之后,高位补充符号位,即为0 提升之后的效果是: 00000000000000000000000000000001
//经典案例
#include <stdio.h> int main() { char a=3; // 00000011 char b=127;//0111111 char c=a+b;//00000000000000000000000010000010--10000010 printf("%d\n",c); return 0; } //--------- -126

浙公网安备 33010602011771号