C语言(长期更新)
第12讲:指针二详解
++跟着潼心走,轻松拿捏C语言,困惑通通走,一去不回头~欢迎开始今天的学习内容++ ++,你的支持就是博主最大的动力++。博主主页:潼心1412o-CSDN博客
目录
[12.1 数组名](#12.1 数组名)
[12.2 一维数组传参的本质](#12.2 一维数组传参的本质)
[12.3 冒泡排序](#12.3 冒泡排序)
[12.5 二级指针](#12.5 二级指针)
[12.6 指针数组](#12.6 指针数组)
[12.7 指针数组模拟二维数组](#12.7 指针数组模拟二维数组)
知识回顾
++今天我们来继续学习指针的内容,坐稳了,我们发车,gogogo,出发喽!++
12.1 数组名
在大多数情况下,数组名==数组首元素的地址
有两个例外
sizeof(数组名)单独放数字名,这时数组名代表整个数组
计算的是整个数组的大小,单位是字节
&数组名,这里数组名代表的是整个数组,去除的事整个数组的地址
12.2 一维数组传参的本质
本质上是数组传参传递的是数组首元素的地址

我们发现同样的计算方式,在函数内部无法正确计算数组的长度
因为在形参的arr是一个首元素的地址,而非数组本身
所以我们之前在扫雷游戏中,每写一个函数,除了传址调用的函数名,还有数组长度
这不仅是以为方便,函数内部是无法用这种方法进行计算的
根据这个本质,我们可以得到结论:
一维数组传参,形参的部分可以写成数组的形式,也可以写成指针的形式
12.3 冒泡排序
核心思想:两两相邻元素进行比较

进阶
要是第一趟下来就没有变动,就无需后续再进行排序了
12.5 二级指针
指针变量也是变量,有变量就有地址。那么至真的地址又该存放在那里呢?
存放在二级指针里

一级指针是一颗*,二级指针就是两颗*
可以这么理解
二级指针指向的类型是int*,而后面的那颗*代表二级指针本身是指针
对二级指针解应用*ppa,得到的会是pa,
想要得到a,就需要对ppa进行两次解应用操作,即**ppa
12.6 指针数组
存放指针的数组

数组中的每个元素都存放指针
12.7 指针数组模拟二维数组

parr[i][j]是什么鬼?怎么就似曾相识呢?
有点像arr[i][j]
我们分析一下,Parr[]中村放的是一维数组的地址,那么parr[i]就对应着arr[i]
我们知道二维数组的本质是一维数组的数组
所以parr[i][j]==arr[i][j]

parr[i]是访问parr数组的元素,parr[i]找到的数组元素指向了整型⼀维数组,parr[i][j]就是整型⼀维数组中的元素。
上述的代码模拟出⼆维数组的效果,实际上并非完全是⼆维数组,因为每⼀行并非是连续的
++好了今天的学习内容就到这里啦,谢谢你的陪伴,我是潼心,下次再见~如果这篇文章对你有帮助的话。请务必给主播一个一键三连,球球了,这对主播很重要~++
博主主页:潼心1412o-CSDN博客