解引用和递增运算符复合表达式是一种很常见的表达,特别是在很多迭代器的使用时,不仅需要返回引用值还需要访问下一个元素,这类复合表达式往往不太能直观理解。
直接举例说明:
class test3
{
public:
void main3()
{
int a[2] = { 10, 20 };
int *p1, *p2, *p3,*p4;
p1 = p2 = p3 = p4 = a;
cout << (*p1)++ << endl;
cout << *p1 << endl;
cout << *(p2++) << endl;
cout << *p2 << endl;
cout << *++p3 << endl;
cout << *p3 << endl;
cout << ++*p4 << endl;
cout << *p4 << endl;
return;
}
};
首先有一个原则:
递增运算符优先级高于解引用运算符。
然后分析上述例子:
(*p1)++ :因为有括号,所以先解引用p1的值,然后值递增,又是后置运算符所以先输出再递增,结果应该为10。
*p1 :接上句,递增后的值应该为11。
*(p2++) :因为有上述原则,所以*(p2++)等价于*p2++,先运算地址递增再解引用值,值得注意的是,p2++是后置递增,所以虽然是先计算递增运算符,但是解引用运算符的操作数仍然是递增前的p2,又上面已经通过p1修改了a[0],所以输出为11。
*p2 :如上所说,是地址递增,而不是解引用后的值,所以输出应该为a[1],即20。
*++p3 :有了上面解释接下来几个就好理解了,先运算地址递增再解引用值,最后输出20。
*p3 :结果不变,20。
++*p4 :先解引用p4的值,然后a[0]=11值递增,又是前置运算符所以先递增再输出,结果应该为12。
*p4 :结果不变,12。
来看输出:
10
11
11
20
20
20
12
12
结果和分析一致。