计算机中整形提升的问题

在这里插入图片描述

在这里插入图片描述

计算机中整形提升讲解

附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日

  • 8
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 11
    评论
评论 11
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

曜摆摆

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值