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

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

相关推荐
FJW0208147 分钟前
Python排序算法
python·算法·排序算法
钮钴禄·爱因斯晨9 分钟前
机器学习(二):KNN算法简介及API介绍(分类、回归)
人工智能·算法·机器学习·分类·回归
如此这般英俊11 分钟前
第八章-排序
数据结构·算法·排序算法
源代码•宸13 分钟前
Leetcode—146. LRU 缓存【中等】(哈希表+双向链表)
后端·算法·leetcode·缓存·面试·golang·lru
郭涤生22 分钟前
AWB算法基础理解
人工智能·算法·计算机视觉
承渊政道23 分钟前
C++学习之旅【C++Vector类介绍—入门指南与核心概念解析】
c语言·开发语言·c++·学习·visual studio
hetao173383724 分钟前
2026-01-21~22 hetao1733837 的刷题笔记
c++·笔记·算法
Hcoco_me26 分钟前
大模型面试题91:合并访存是什么?原理是什么?
人工智能·深度学习·算法·机器学习·vllm
2501_9011478329 分钟前
零钱兑换——动态规划与高性能优化学习笔记
学习·算法·面试·职场和发展·性能优化·动态规划·求职招聘
充值修改昵称2 小时前
数据结构基础:B树磁盘IO优化的数据结构艺术
数据结构·b树·python·算法