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
复制代码

 

posted @   小白的进阶之旅  阅读(62)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 展开说说关于C#中ORM框架的用法!
点击右上角即可分享
微信分享提示