1 #include <iostream> 2 3 using namespace std; 4 5 #define f(x) ((x) * (x)) 6 7 int main(int argc, char **argv) 8 { 9 int m = 3; 10 11 std::cout << "f(m) = " << f(m) << std::endl; // 可以解析为: (m) * (m) ------> 3 * 3 == 9
//可以解析为: (m++) * (m++) 由于后置++是先用后自加,所以可以直接理解为就是两个m相乘然后在运行自增。 12 std::cout << "f(m++) = " << f(m++) << std::endl;
//同理,前置++是先自加后用,所以理解为m先自增两次,然后自增后再相乘。 13 std::cout << "f(++m) = " << f(++m) << std::endl; 14
//下面的语句可以用来验证上面的解释。如果还是不能理解可以直接gdb调试,查看变量值的变化情况。 15 int j = 3; 16 std::cout << "XXXX (j++) * (j++) = " << (j++) * (j++)<< std::endl; 17 std::cout << "XXXX (++j) * (++j) = " << (++j) * (++j)<< std::endl; 18 19 return 0; 20 }
运行结果:
xchonxu/testCode> ./a.out
f(m) = 9
f(m++) = 9
f(++m) = 49
XXXX (j++) * (j++) = 9
XXXX (++j) * (++j) = 49