c语言中整型算术运算总是以至少以缺省整型类型的精度来进行的,为了获取这种精度,表达式中的字符和短整型操作数在使用之前转换为普通整型,这种转换称为整型提升。
整型提升分为有符号的整型提升和无符号的整型提升。
有符号的整型提升按照变量数据类型的符号位来提升;无符号的整型提升按照高位补0来提升。
比如定义了三个char类型的数,现在把其中两个数相加并赋值给第三个数,相加的两个数就要进行整型提升。相加的结果赋给第三个数时需要进行截断,因为int型在内存中占4个字节,char型占1个字节。
#include<stdio.h>
int main()
{
//发现a和b都是char类型,没有达到一个int大小
//此时发生整型提升,按照变量数据类型的符号位来提升
char a = 3;
//00000011 实际存储
//000000000000000000000011 整型提升后
char b = 127;
//01111111 实际存储
//000000000000000001111111 整型提升后
char c = a + b;
//000000000000000010000010
//10000010 发生截断
printf("%d\n",c);
//打印整型,所以又进行整型提升
//111111111111111110000010 整型提升后
//注意此时c为负数,内存中存放的是补码
//111111111111111110000001 反码
//100000000000000001111110 原码
//所以打印结果为-126
return 0;
}
在计算过程中需要注意负数在内存中的存储形式。
版权声明:本文为minLi_原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。