目录
?
C语言中的整型算术运算总是以缺省(默认)整型类型的精度来进行的。为了获得这个精度,表达式中的字符和短整型操作数在使用之前会被转换为普通整型。那么将这种转换称为整型提升。
理解:整型提升的对象是两种:①表达式中的字符类型和短整型
②整个过程是操作系统偷偷做的,不会表现出来,先将数据进行整形提升过后再参与运算。
①表达式的整型运算要在CPU的相应运算器件内执行1,cpu内整型运算器的操作数的字节长度一般就是int的字节长度为4个字节,同时也是cpu的通用寄存器的长度。因此,即是两个char类型的相加,在cpu执行时实际上也要先转换为cpu内整型操作数的标准长度。
②
通用cpu是难以直接实现两个8比特字节直接相加运算(虽然机器指令中可能有这种字节相加指令)。
比如:一个char是1个字节,为八个比特位,当两个char相加的时候就有可能发生进位,那么就有可以得到一个9比特位的数据,那么存储空间只有8个比特位就可能发生截断,数据就是错误的。
所以,表达式中各种长度小于int长度的整型值,都必须转换为int,再送入cpu进行运算。?
总的规则:整型提升是根据变量的数据类型的符号位来进行提升的
对于负数来说:
char c1 = -1;
c1在内存中存储的二进制序列(补码)为:
11111111
整型提升的时候,高位补充符号位,即补充1
整型提升后的结果为:11111111 11111111 11111111 11111111
对于正数来说:
char c2 = 1;
c2在内存中存储的二进制序列(补码)为:
00000001
整型提升的时候,高位补充符号位,即是补充0:
00000000 00000000 00000000 00000001
对于无符号的整型来说高位直接补0?
大家也可以看一下上一篇题解,也是运用整型提升的实例
这篇文章可以作为整型在内存中的存储相关篇章的辅助知识,也是在学习C语言路上的一个热门基础知识,大家可以结合例子好好理解一下,不对的地地方欢迎大家指正。