详解指针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)指针数组的定义和用途。文章通过代码示例和内存分析,帮助读者深入理解这些关键指针概念。


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

相关推荐
A-code1 小时前
C/C++ 中 void* 深度解析:从概念到实战
c语言·开发语言·c++·经验分享·嵌入式
编程之路,妙趣横生5 小时前
详解C语言操作符
c语言
Fuchsia5 小时前
Linux软件编程笔记五——进程Ⅰ
linux·c语言·笔记·操作系统·进程
林一百二十八5 小时前
在Ubuntu上学习C语言(一)
c语言·学习·ubuntu
ZIM学编程7 小时前
「学长有话说」作为一个大三学长,我想对大一计算机专业学生说这些!
java·c语言·数据结构·c++·python·学习·php
子枫秋月8 小时前
单链表实现全解析
c语言·数据结构·c++
消失的旧时光-19439 小时前
c语言 内存管理(malloc, calloc, free)
c语言·开发语言
degen_9 小时前
注册协议通知
c语言·笔记
Yupureki10 小时前
从零开始的C++学习生活 19:C++复习课(5.4w字全解析)
c语言·数据结构·c++·学习·1024程序员节
NEU-UUN11 小时前
C语言 . 第三章第二节 .递归函数
c语言·开发语言