小菜鸟第一次写博客啦!以后会尽量更,一开始讲得很浅,接下来会一点一点深入
int
main()
{
int
arr[]={
1
,
2
,
3
,
4
,
5
,
6
,
7
};
int
*p=arr;
*(p++)+=
89
;
printf(
"%d,%d\n"
,*p,*(++p));
return
0
;
}
前两天碰巧看到这道题,粗浅一看,代码少,结构简单,送分的吧,然后算了半天都没算出来,你可以尝试算算,最后运行了一下,输出是
3,3
#include<iostream>
using namespace std;
int main()
{
int arr[]={1,2,3,4,5,6,7};
int *p=arr;
printf("*p=%d,*p=%d,*p=%d,*p=%d\n",*p,*p,*p,*p);
return 0;
}
using namespace std;
int main()
{
int arr[]={1,2,3,4,5,6,7};
int *p=arr;
printf("*p=%d,*p=%d,*p=%d,*p=%d\n",*p,*p,*p,*p);
return 0;
}
超简单,清一色输出1
然后对第二个p后置+
有点奇怪,为什么前面反而加1?
然后对第三个p后置+(附上代码)
好像找到了规律,原来printf是从右往左输出的,所以与我们的预期相反,也就是第三个p(简称p3)++后,往左边的才开始输出,而因为是后置,所以p3自身没加,p4同理
接下来这张图就意料之中了
现在换成前置+
区别出来了,p++中的p2为1,在这里为2,同时也发现,p1和p2一直是一样的!
所以上面那道题的答案两者一定是一样的,都是++p,了解了以上细节再分析代码
int
main()
{
int
arr[]={
1
,
2
,
3
,
4
,
5
,
6
,
7
};
int
*p=arr;
*(p++)+=
89
;
printf(
"%d,%d\n"
,*p,*(++p));
return
0
;
}
*(p++)+=89表示p指针指向的数值增加了89,也就是arr[0]=90,然后再p++,此时p==2,为什么不是p++指针指向的数值增加89呢?不是有个括号吗?
从图中很明显,后置加即使有括号,也是先赋值再自加的
接下来就简单了++p从右往左输出,当然是两个3啦