看了一本叫做《程序员面试宝典》的书,上面有一题是这样的:
#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