计算机中整形提升讲解
附1:
大家猜猜下面程序的运行结果是多少?
如果你的答案是0,那么恭喜你答对了。
解析:那么答案为什么是0呢?接下来我就用计算机底层的计算原理手把手告诉你这是为什么?在这之前需要先介绍下整形提升。
整形提升的意义:
表达式的整型运算要在CPU的相应运算器件内执行,CPU内整型运算器(ALU)的操作数的字节长度
一般就是int的字节长度,同时也是CPU的通用寄存器的长度。
因此,即使两个char类型的相加,在CPU执行时实际上也要先转换为CPU内整型操作数的标准长
度。
通用CPU(general-purpose CPU)是难以直接实现两个8比特字节直接相加运算(虽然机器指令
中可能有这种字节相加指令)。所以,表达式中各种长度可能小于int长度的整型值,都必须先转
换为int或unsigned int,然后才能送入CPU去执行运算。
附2:如何提升?(我这是32位平台下的二进制计算)
1、整形提升是按照变量的数据类型的符号位来提升的。(最高位是1代表负数,那么整形提升就是在前面全部补1;最高位是0代表正数,那么整形提升就是在前面全部补0。)
2、无符号整形提升,高位补0。
3、接下来我将用代码演示的方式为大家解析本题
代码演示:
3个变量的随机初始化,其中内存1代表x变量,内存2代表y变量,内存3代表z变量
x、y变量指定初始化和z经过运算赋值后的结果
演示代码提取:
#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
int main()
{
char x = -1;
//为了让大家理解,我用无符号整形打印出来char类型的-1给大家看
printf("%u\n", x);
int y = 1;
int z = x + y;
printf("%d\n", z);
return 0;
}
//10000000000000000000000000000001(char类型-1的原码)
//11111111111111111111111111111110(char类型-1的反码)
//11111111111111111111111111111111(char类型-1的补码)
//char类型所占空间是1个字节,也就是8个比特位,计算机规定舍弃前面24位,保留最后8位
//11111111
//接下来char类型强制转换为int类型开始按照计算机规定的整形类型提升的方法进行整形提升
//因为最高位是1,所以前面24位全部补1
//11111111111111111111111111111111(强制转换成int类型的结果)
//00000000000000000000000000000001(int类型1的原码、反码、补码)
//开始计算
//11111111111111111111111111111111
//00000000000000000000000000000001
//00000000000000000000000000000000(计算结果)
备注:
楼主不才,不喜勿喷,若有错误或需要改进的地方,非常感谢你的指出,我会积极学习采纳。谢谢家人们一直以来的支持和鼓励,我会继续努力再接再励创作出更多优质的文章来回报家人们的。编程爱好的xdm,若有编程学习方面的问题可以私信我一同探讨(我尽力帮),毕竟“众人拾柴火焰高”,大家一起交流学习,共同进步!
2021年12月12日