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

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

相关推荐
NAGNIP6 小时前
大模型框架性能优化策略:延迟、吞吐量与成本权衡
算法
美团技术团队7 小时前
LongCat-Flash:如何使用 SGLang 部署美团 Agentic 模型
人工智能·算法
Fanxt_Ja12 小时前
【LeetCode】算法详解#15 ---环形链表II
数据结构·算法·leetcode·链表
侃侃_天下12 小时前
最终的信号类
开发语言·c++·算法
茉莉玫瑰花茶12 小时前
算法 --- 字符串
算法
博笙困了12 小时前
AcWing学习——差分
c++·算法
NAGNIP12 小时前
认识 Unsloth 框架:大模型高效微调的利器
算法
NAGNIP12 小时前
大模型微调框架之LLaMA Factory
算法
echoarts12 小时前
Rayon Rust中的数据并行库入门教程
开发语言·其他·算法·rust
Python技术极客12 小时前
一款超好用的 Python 交互式可视化工具,强烈推荐~
算法