i++*i++的问题

       看了一本叫做《程序员面试宝典》的书,上面有一题是这样的:

#define PRODUCT(x) (x*x)
main()
{
int i=3,j,k;
j=PRODUCT(i++);
k=PRODUCT(++i);
printf("/n%d%d",j,k);
}

答案是9,49.

我是迷惑了,所以就到处去找答案,想知道到底为什么。结果是这样的:

i++不是一个即时的运算符,他可能在一个序列结束之后再做加的运算。(这个序列应该是具有较高优先级的)在这道题中,可以这样理解:先是:i*i,再两次i++。然后先两次++i,再做i*i. 优先级是这样的:i++<*<++i.

但是,这个问题并没有在语言中定义出来。所以依赖于个人的理解。也就是说,取决于具体的编译器。

类似的一个问题是:

int i = 3;
i = i++;

有的编译器是3,有的是4.

解决的方法就是:不用带有歧义的运算式。可以用简单的,分布的运算。

最后,注意,i++或者++i都不同与i+1.

ps:相关问题请参看:http://c-faq.com/index.html

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值