对*P++的理解,再联想~~~

来源:本站
导读:目前正在解读《对*P++的理解,再联想~~~》的相关信息,《对*P++的理解,再联想~~~》是由用户自行发布的知识型内容!下面请观看由(电工技术网 - www.9ddd.net)用户发布《对*P++的理解,再联想~~~》的详细说明。
简介:*P++,这种用法是很常见的,很有用的。但是不是很好理解,现在来彻底分析下~~

首先*号和++号的优先级是同一级,但是它们的结合方向是从右边到左边。

那么很明显核心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,参数列表为空)

提醒:《对*P++的理解,再联想~~~》最后刷新时间 2024-03-14 01:02:42,本站为公益型个人网站,仅供个人学习和记录信息,不进行任何商业性质的盈利。如果内容、图片资源失效或内容涉及侵权,请反馈至,我们会及时处理。本站只保证内容的可读性,无法保证真实性,《对*P++的理解,再联想~~~》该内容的真实性请自行鉴别。