首先*号和++号的优先级是同一级,但是它们的结合方向是从右边到左边。
那么很明显核心P先和++先结合,这个就确定了关键的一件事——++会让指针递增,而不是指针指向的数,
也就是说会递增的是p而不是*p。
但是这里的++,是后++。后++有个特点——++会在本条语句执行完之后执行。
知道了,这些之后*P++就可以理解了,他就等价于:先执行*P,然后将P++。
1、首先找核心。这里是P。(核心其实就是关键变量)
2、然后找结合,先看核心离谁最近,再看核心更喜欢谁(优先级),结合之后就可以把结合形成的东西看成整体。
如,这里就是P++;那么就是*(P++)。但是这里++的特殊性,会先执行*P,但是P++始终是整体,
所以之后会执行P++,而不是(*P)++。
数组指针与指针数组也是这么分析:
int* p[];
首先核心是p,再看p更喜欢谁~~
[]是最高优先级的运算符(小括号排名第二,但是我们知道[]里只能放常量,无法放变量,而核心往往是变量所以看上去小括号更牛逼些)。
所以p先和[]结合,和[]结合之后就成了p[],很明显这是个数组,p[]再和*结合就成了*p[],
就成了指针数组,应为p先[]结合,int* p[]的本质是个数组,然后数组内部存放的是int型的指针。
再看指针数组:
int(*p)[];分析流程还是遵循以上规则:
首先找到核心p,小扩宽把p与[]隔开了,那么此时p和*最近,他们可以结合,且结合成*p,很明显*p是一个指针的形式,*p整体再和[]结合,这就成了数组指针,应为p先和*结合,所以他的本质是一个指针,这个指针指向了一个int型的数组。
再看指针函数:
int *add();
首先核心是add,add先和优先级更高的小括号结合,就成了一个整体add(),很明显这是个函数。
add()整个再和*结合,就是指针函数了。应为add先和小括号结合,所以他的本质是一个函数。
一个能返回(一个int型)指针的函数。
最后看函数指针:
int (*add) ();此时add被一个小扩隔开了,此时add和*最近,他们先结合,所以int (*add) ()本质是一个指针,这个整体再和小括号结合,就成了函数指针。本质是指针,所以这个是一个指向函数的指针。
(函数的特点是返回值为int,参数列表为空)