昨天,有人问我下面的程序输出结果是什么,特此记录下来
#include <iostream>
#define put(x) ((x)*(x))
using namespace std;
int main() {
int a[3] = {1,2,3};
int i = 0;
int b = 3;
int c;
c = put(a[i++]);
cout << c << endl;
getchar();
return 0;
}
用到了宏定义函数,在使用时需要展开,即
c = (a[i++]) * (a[i++]);
在vs 2008的环境下,输出是1, a[0]*a[0] = 1
个人的理解为当i++在一条语句当中出现两次时,编译器会做优化,即 i 先保持不变,取a[0] a[0] 之后,i 自增两次变成2。
#include <iostream>
#define put(x) ((x)*(x))
using namespace std;
int main() {
int a[3] = {1,2,3};
/*int i=0;
cout << a[i++] << endl;*/
int i = 0;
int b = 3;
int c;
c = put(a[++i]);
cout << c << endl;
getchar();
return 0;
}
稍稍做些变化,将上面的i++ 编程 ++i ,c = (a[++i]) * (a[++i]); ++i 出现两次在一个语句中。
此时,编译器在做处理时,会先将i 自增两次,最后结果为a[2]*a[2] = 9
总结出这一类编译器的规律, 即i++可以认为是先取i的值,后对i进行自增处理,则索性全部先取值,后自增。
++i 可以认为是先自增,再取值,则索性全部自增之后,再进行操作。