指针易混淆概念:*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为指向函数的指针,该函数返回一个整型值

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

相关推荐
快去睡觉~3 小时前
力扣73:矩阵置零
算法·leetcode·矩阵
小欣加油4 小时前
leetcode 3 无重复字符的最长子串
c++·算法·leetcode
猿究院--王升7 小时前
jvm三色标记
java·jvm·算法
一车小面包7 小时前
逻辑回归 从0到1
算法·机器学习·逻辑回归
tt5555555555558 小时前
C/C++嵌入式笔试核心考点精解
c语言·开发语言·c++
科大饭桶8 小时前
C++入门自学Day14-- Stack和Queue的自实现(适配器)
c语言·开发语言·数据结构·c++·容器
tt5555555555558 小时前
字符串与算法题详解:最长回文子串、IP 地址转换、字符串排序、蛇形矩阵与字符串加密
c++·算法·矩阵
元亓亓亓9 小时前
LeetCode热题100--101. 对称二叉树--简单
算法·leetcode·职场和发展
不会学习?10 小时前
算法03 归并分治
算法
NuyoahC10 小时前
笔试——Day43
c++·算法·笔试