#include <stdio.h>
int main()
{
int arr[] = { 6, 7, 8, 9, 10 };
int *ptr = arr;
*(ptr++) += 123;
printf("%d,%d\n", *ptr, *(ptr++));
return 0;
}
程序运行结果为:
8,7
1.解释:*(ptr++) += 123这句代码中,使用了后++
所以效果相当于:*ptr(6)+123=129;
ptr+=1;
也就是运行后*ptr指向larr[1];
2.解释:printf(“%d,%d\n”, ptr, (ptr++));这句代码的执行涉及到汇编的函数的参数的压栈过程是从后面的参数开始压栈的,所以*(ptr++)会先被压栈,导致ptr++首先生效(引用别人的 因为我不会汇编)
所以往栈里压入*ptr时,此时的ptr已经变成指向arr[2]了
同理一下代码的运行结果为8,8;
#include <stdio.h>
int main()
{
int arr[] = { 6, 7, 8, 9, 10 };
int *ptr = arr;
*(ptr++) += 123;
printf("%d,%d\n", *ptr, *(++ptr));
return 0;
}
为了更好的理解我搜了其他人用OD将程序反汇编得到的汇编代码:
还是不理解*ptr++的话那就看如下代码:
int i = 1;
printf("%d\n", i++);
printf("%d\n", i);
运行结果为1 2;上面道理是一样的。
扩展:
(*p)++和*p++的概括
(*p)++指的是先取出p指向的存储单元中的内容,然后将取出的数值加1,而p仍然指向原来的存储单元。
*p++则指的是先取出p指向的存储单元中的内容,然后将p值加1,此时p不再指向原来的存储单元。
表达式(*p)++和*p++具有不同的含义,(*p)++并没有修改指针p的指向,而*p++则修改了指针p的指向。
本文仅仅是自己留作纪念自己的知识总结,不足大家批评哈。谢谢!