详解指针2

上期内容我们已经学习了指针的基础知识,本期博主给大家分享一下指针的进阶内容继续深入了解指针;

大纲

一、数组名的理解

举个栗子,便于更好的理解:

我们发现&arr和&arr[0]拿到的地址是一样的;因此我们可以得出一个结论:

数组名==数组首元素地址

接下来我们继续分析代码:

大家都了解了数组名==数组首元素地址,一个整型占4个字节;那么答案就是4/8;答案是40;

注意:数组名==数组首元素地址是成立的,但是有两个例外:

  • sizeof(数组名):sizeof中单独存放数组名,这里的数组名表示整个数组,计算的是整个数组的大小,单位是字节;
  • &数组名:这里的数组名表示整个数组,取出的是整个数组的地址


这⾥我们发现&arr[0]和&arr[0]+1相差4个字节,arr和arr+1 相差4个字节,是因为&arr[0] 和 arr 都是 ⾸元素的地址,+1就是跳过⼀个元素。 但是&arr 和 &arr+1相差40个字节,这就是因为&arr是数组的地址,+1 操作是跳过整个数组的。 到这⾥⼤家应该搞清楚数组名的意义了吧。

二、使用指针访问数组

通过调试代码,我们发现数组名arr是数组⾸元素的地址,可以赋值给p,其实数组名arr和p在这⾥是等价的。

通过调试代码将*(p+i)换成p[i]也是能够正常打印的,所以本质上p[i] 是等价于 *(p+i)。同理arr[i] 应该等价于 *(arr+i),数组元素的访问在编译器处理的时候,也是转换成⾸元素的地址+偏移 量求出元素的地址,然后解引⽤来访问的。

三、一维数组传参的本质


总结⼀维数组传参,形参的部分可以写成数组的形式,也可以写成指针的形式。

四、冒泡排序

冒泡排序的核⼼思想就是:两两相邻的元素进⾏⽐较。

接下来我们使用代码来实现这个过程:

方案一:

方案二:

五、二级指针

指针变量也是变量,是变量就有地址,那指针变量的地址存放在哪⾥?
二级指针

六、指针数组

指针数组到底是指针还是数组呢?

答案是数组;是用来存放指针的数组。

指针数组的每个元素都是⽤来存放地址(指针)的。

指针数组的每个元素是地址,⼜可以指向⼀块区域;

总结

本文深入讲解了指针的进阶知识,重点包括:1)数组名的特殊含义,指出数组名通常代表首元素地址,但在sizeof和&操作时例外;2)指针访问数组的原理,解释p[i]等价于*(p+i)的底层实现;3)一维数组传参的两种形式(数组和指针);4)冒泡排序的实现原理;5)二级指针的概念及其存储指针变量地址的作用;6)指针数组的定义和用途。文章通过代码示例和内存分析,帮助读者深入理解这些关键指针概念。


转眼间又要和大家说再见了,以上就是博主要给大家分享的所有内容了;希望大家能有所收获,可以的话请三连支持一下;你的支持是我持续创作最大的动力;

相关推荐
SuperByteMaster8 小时前
keil 工程 .gitignore配置文件
c语言
老花眼猫12 小时前
编制椭圆旋转绘图函数
c语言·经验分享·青少年编程·课程设计
iCxhust15 小时前
微机原理实践教程(C语言篇)---A002流水灯
c语言·开发语言·单片机·嵌入式硬件·51单片机·课程设计·微机原理
qeen8715 小时前
【数据结构】建堆的时间复杂度讨论与TOP-K问题
c语言·数据结构·c++·学习·
handler0115 小时前
Linux 内核剖析:进程优先级、上下文切换与 O(1) 调度算法
linux·运维·c语言·开发语言·c++·笔记·算法
热心网友俣先生16 小时前
2026年第二十三届五一数学建模竞赛C题超详细解题思路+各问题可用模型推荐+部分模型结果展示
c语言·开发语言·数学建模
li16709027017 小时前
第二十七章:智能指针
c语言·数据结构·c++·visual studio
Aurorar0rua19 小时前
CS50 x 2024 Notes C - 07
c语言·学习方法
爱编码的小八嘎19 小时前
C语言完美演绎9-15
c语言
weixin_4217252619 小时前
C语言常用字符串函数:长度、比较、拼接和查找
c语言·字符串函数·查找·比较·长度