(++i)+(++i)+(++I)问题的解决:

(++i)+(++i)+(++I)问题的解决:

今天碰到了这个题:

int main()
{
    int i=1;
    int ret=0;
    ret=(++i)+(++i)+(++i);
    printf("%d\n",ret);
    printf("%d\n",i);
    return 0;
}

先说一下运行结果

VS2013: 12 1543836363910

linux: 10 1543836440615

初一看,结果不应该是9(2+3+4)吗,是搞错了吗?

当然不是,经过了大量的查寻资料和实验,最后得出了结论:

vc/linux: 这俩个是这样处理的,在进行加法运算时,求出了左值和右值后,就求出他们的和,再进行下一步运算。

​ (i=1,运行++i之后,i=2;运行++i后,i=3;在求出了+所需的俩个操作数之后,计算出俩个数的和放到寄存器中,这俩个操作数的位置就是当前的位置,所以3+3=6,放到寄存器中;现在对最后一个+,有了左值,右值还不确定,++i,i=4;6+4=10;)

vs:在多个式子相加时,先求出各个因式的值,最后一起执行加法操作。

​ ( 也就是++i,++i,++i全部执行完,再求和。++i,i=2;++i,i=3;++i,i=4;然后4+4+4=12;)

另:最后实验了以下4种可能,同样也符合这个结论。

++i)+(++i)+(++i);
(++i)-(++i)-(++i);
(--i)+(--i)+(--i);
(--i)-(--i)-(--i);
  • 14
    点赞
  • 39
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值