指针p++,*p++,(*p)++,*(p++)的区别

p是一个指针,p++,*p++,(*p)++,*(p++)这四个加到底是加在地址上还是加在值上呢?直接上测试代码我们看:

#define SELPLUS
//#define PLUS
//#define MINUS
//#define MULTIPLY
//#define DIVID

	int buf1[5] = { 1, 3, 5, 7, 9};
	int buf2[5] = { 1, 3, 5, 7, 9};
	int buf3[5] = { 1, 3, 5, 7, 9};
	int buf4[5] = { 1, 3, 5, 7, 9};
	int *p1 = NULL;
	int *p2 = NULL;
	int *p3 = NULL;
	int *p4 = NULL;
	p1 = &buf1[1];
	p2 = &buf2[1];
	p3 = &buf3[1];
	p4 = &buf4[1];
#ifdef SELPLUS
	p1++;
	*p2++;
	(*p3)++;
	*(p4++);
#endif 
#ifdef PLUS
	p1=p1+1;
	*p2=*p2+1;
	*p3=(*p3)+1;
	*p4=*(p4+1);
#endif 
#ifdef MINUS
	p1=p1-1;
	*p2=*p2-1;
	*p3=(*p3)-1;
	*p4=*(p4-1);
#endif 
#ifdef MULTIPLY
	*p2=*p2*2;
	*p3=(*p3)*2;
#endif 
#ifdef DIVID
	*p2=*p2/2;
	*p3=(*p3)/2;
#endif

	cout << *p1 << endl;
	cout << *p2 << endl;
	cout << *p3 << endl;
	cout << *p4 << endl;

	system("pause");

结果上图:
在这里插入图片描述
结果很明显
p++,*p++,*(p++)是在p所指向的地址上+1

(*p)++是在p所指向的数据上+1

同理,再接着测试加减乘除(对地址直接乘除非法,所以乘除只测试两种),分别得到以下结果:

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
结论如下:
加法(同减):
p+1,*(p+1)是对p指向的地址+1
*p+1,(*p)+1是对p指向的数据+1
乘法(同除):
*p*2,(*p)*2都是对p指向的数据×2

### C/C++指针 `p+1` 和 `p++` 的区别及应用场景 #### 一、基本概念 在 C/C++ 编程语言中,指针是一种特殊的变量类型,用于存储其他变量的内存地址。对于指针的操作符 `+` 和 `++` 而言,其行为取决于指针的数据类型以及上下文环境。 当提到 `p+1` 或者 `p++` 时,实际上涉及到了两种不同的运算逻辑: - **`p+1`**: 表达式的值等于当前指针加上一个偏移量后的结果,但原指针不会改变。 - **`p++`**: 原始指针会自增一次,并返回原始或者更新后的值(依据前缀或后缀形式)。 具体来说,在这两种情况下,指针都会基于其所指向数据类型的大小来调整自己的数值[^1]。 #### 二、技术细节分析 ##### (一) 关于 `p+1` 假设有一个整型数组 int a[] 并定义了一个指向该数组第一个元素的指针 int *p=a; 那么执行 p+1 后并不会真正修改 p 自身的内容,而是计算并得到一个新的临时指针位置,这个新位置相对于原来的 p 移动了一格(即 sizeof(int))。 ```cpp int main() { int arr[5]; int* ptr = &arr[0]; printf("%d\n", *(ptr + 1)); // 输出第二个元素的值 } ``` 上述代码片段展示了如何利用 `(ptr + 1)` 来访问下一个连续存储单元中的内容而无需显式更改原有指针的位置。 ##### (二) 对应 `p++` 相比之下,如果采用的是 `p++`, 则不仅会产生新的指针值,还会永久性地影响到实际使用的那个指针对象本身。需要注意的是,这里存在前置(`++p`)与后置(`p++`)之分: - 如果是前置版本,则先增加再使用; - 若为后置模式,则反之——先是用旧址完成相应动作后再做位移处理. 下面通过一段简单的程序进一步说明两者之间的差异之处: ```cpp #include <iostream> using namespace std; void showAddressAndValue(int *q){ cout << "Pointer Address: "<< q<< ", Value at Pointer Location:"<< *q<<"\n"; } int main(){ int b[]={10,20}; int *r=&b[0]; showAddressAndValue(r); r++; // Postfix incrementation. showAddressAndValue(r); --r; ++r;// Prefix incrementation. showAddressAndValue(r); return 0;} ``` 在这个例子当中我们可以看到无论是哪种方式实现加法操作最终都将使得我们的指针向前推进至下一位有效地址处;但是它们作用发生的时间点有所不同从而可能引起后续一系列连锁反应上的差别表现出来. #### 三、总结对比表 | 特征 | \(p+1\) | \(p++\) | |--------------|----------------------------------|---------------------------------| | 是否改变原指针状态 | 不变 | 改变 | | 返回的结果 | 新建的一个临时指针 | 可能是原有的或者是已经改变了的那个 | 综上所述,理解这两者的细微差别有助于编写更加精确高效的C/C++应用程序。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值