表达式求值(整型提升,隐式类型转换,寻常类型转换顺序)

隐式类型转换

隐式提升与截断char a=5;

5---->00000000000000000000000000000101

char 5----->00000101

int类型是四个字节32个bit位

char类型是一个字节8个bit位


整形提升

c语言中会将表达式中的字符和短整型操作数在使用之前被转换为普通整形,这种转换就是整形提升

int main()
{
    char a=5;
    char b=126;
    char c=a+b;
    printf("%d",c);//这里的%d需要的是整形,而a和b都为char类型
    return 0;
    //最终结果为-125
}

整形提升的意义:

表达式的整形运算要在CPU相应运算器件内执行,CPU内整形运算器(ALU)的操作数的字节长度一般就是int的字节长度,同时也是CPU的通用寄存器长度。

通用CPU难以直接实现两个8比特字节直接相加运算(虽然机器指令中可能有这种字节相加指令)。所以表达式里各种长度可能小于int长度的整型值都得先转为int 或unsigned int才能送入CPU去执行计算

如何进行整形提升

整形提升是按照变量的数据类型的符号位来提升

注意:无符号数整型提升时前面补0

int main()
{
    char a=5;
    char b=126;
    //a
    //5的原本二进制
    //00000000000000000000000000000101
    //因为char类型是一个字节的大小,一个字节等于八个bit位,所以截断后:
    //00000101
    //b
    //原本126的二进制
    //00000000000000000000000001111110
    //截断后:
    //01111110
    char c=a+b;
    //表达式计算时要发生整形提升,而相加完后为补码要先截断回去,
    //截断后又要整型提升(补符号位的数)然后再变为原码输出
    printf("%d",c);
    //这里的%d应该为int型,所以要使用的话要整型提升
}

注意:


寻常类型转换

 

tip:
如果是sizeof( _ = _);表达式,最终类型以等号左边为主

原因:sizeof内部表达式不会真实地去计算

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值