p++先返回指针原值再自增,(p)++与p++完全等价,++p先自增再返回新值,三者中仅前置与后置有行为差异,括号不改变运算结果。
在C++中,p++、(p)++ 和 ++p 都涉及指针的自增操作,它们的行为非常相似,但使用场景和表达式类型略有不同。下面详细解释它们的区别。
p++(后置自增)
表达式 p++ 是指针 p 的后置自增操作。它会先返回 p 的当前值,然后将指针 p 向后移动一个元素的位置(即增加 sizeof(所指类型) 的字节数)。
例如:
p++ 返回的是 p 的原始值,之后 p 指向下一个元素。
int arr[3] = {10, 20, 30};
int* p = arr; // p 指向 arr[0]
int* q = p++; // q 指向 arr[0],之后 p 指向 arr[1]
(p)++(带括号的后置自增)
(p)++ 和 p++ 完全等价。括号在这里没有改变运算优先级或行为,因为后置 ++ 的优先级本来就高于大多数运算符,且 p 本身是一个左值。
立即学习“C++免费学习笔记(深入)”;
换句话说,(p)++ 只是 p++ 的一种加括号写法,语义和效果完全相同。
例如:
int* q = (p)++; // 等同于 p++
这种写法很少见,通常没有实际必要,但在宏定义或模板中可能用于避免歧义。
++p(前置自增)
++p 是前置自增操作。它先将指针 p 增加一个元素的位置,然后返回增加后的新地址。
例如:
int arr[3] = {10, 20, 30};
int* p = arr;
int* q = ++p; // p 先指向 arr[1],然后 q 也指向 arr[1]
与 p++ 不同,++p 返回的是自增后的新值。
关键区别总结
- p++:先使用 p 的值,再自增。返回的是自增前的指针值。
- (p)++:与 p++ 完全相同,括号无实际影响。
- ++p:先自增,再使用新值。返回的是自增后的指针值。
注意:这些操作都要求指针 p 是一个可修改的左值(即非 const 指针变量),否则会编译错误。
基本上就这些。指针自增的行为取决于前置还是后置,括号不影响结果。理解它们对遍历数组或链表很有帮助。