指针易混淆概念:*p++,*(p++),++(*p)

(1)a[1]和&a[1]

a[1]:二维数组的第二行元素,即a[1]是以a[1][0]开头的一维数组,类型是一级指针

&a[1]:二维数组的第二行元素的地址,类型是二级指针

(2)a+1与*(a+1)的值相同

很多人认为,a+1是地址,那么*(a+1)就是该地址指向的存储单元的内容,为什么会是一个值

答:

a+1是二维数组序号为1的行的起始地址,而*(a+1)并不是a+1单元的内容,因为a+1不是一个数组元素的地址,也就谈不上是存储单元的内容了,所以*(a+1)就是a[1],而a[1]是一维数组名,指向a[1][0],所以*(a+1)和a[1]都是a[1][0]的地址

(3)a[1]+2,&a[1][2]

a[1]+2,&a[1][2]和*(a+1)+2

都表示 1行2列元素a[1][2]的地址

(4)*p++,*(p++),++(*p)

因为++和*同优先级,结合方向为自右向左,所以*p++=*(p++)

*(p++):先取*p值,再使p加1,以&a[0]为例,若输出*(p++),则得到a[0]

*(++p):先使p加1,再取*p的值,也以&a[0]为例,若输出*(++p)得到a[1]

++(*p):表示p所指向的元素加1,如果p=a,++(*p)相当于++a[0],若a[0]=3,那么++(*p)=4,注意是a[0]的值加1,而不是指针p的值+1

(5)int(*p)[n],int *p[n]

int (*p)[n] 表示定义一个指针,指向一个int[n]型的指针。

例如:int(*p)[4]

p为指向包含4个元素的一维数组的指针变量

int *p[n] 就是一个指针数组, 数据类型为int ,元素为地址(变量地址,数组地址,函数地址等),也就是说定义了n个不同指向int型的指针。在字符优先级表中,[ ]的优先级大于*,所以,int *p[n] 就等价于int *(p[n])

例如:int *p[4]

定义指针数组p,他由4个指向整型数据的指针元素组成

(6) int *p(),int (*p)()

int *p():p为返回一个指针的函数,该指针指向整形数据

int (*p)():p为指向函数的指针,该函数返回一个整型值

先记录这一些,再遇到问题会继续记录下来💓💓💓

相关推荐
远望清一色7 分钟前
基于MATLAB身份证号码识别
开发语言·图像处理·算法·matlab
子朔不言12 分钟前
[ARM-2D 专题]6.脏矩形定义的宏使用技巧和分析
c语言·arm开发·arm2d·显控开发-新龙微
BT-BOX1 小时前
STM32仿真proteus位带操作和keil增加头文件C文件
c语言·stm32·proteus
醉颜凉1 小时前
【NOIP提高组】潜伏者
java·c语言·开发语言·c++·算法
lapiii3581 小时前
图论-代码随想录刷题记录[JAVA]
java·数据结构·算法·图论
Dontla3 小时前
Rust泛型系统类型推导原理(Rust类型推导、泛型类型推导、泛型推导)为什么在某些情况必须手动添加泛型特征约束?(泛型trait约束)
开发语言·算法·rust
Ttang233 小时前
Leetcode:118. 杨辉三角——Java数学法求解
算法·leetcode
喜欢打篮球的普通人3 小时前
rust模式和匹配
java·算法·rust
java小吕布3 小时前
Java中的排序算法:探索与比较
java·后端·算法·排序算法