您的位置:首页 > 汽车 > 新车 > 深入理解指针(2)

深入理解指针(2)

2025/1/10 18:48:54 来源:https://blog.csdn.net/qq_74775863/article/details/140878699  浏览:    关键词:深入理解指针(2)

1. 数组名的理解

2. 使⽤指针访问数组

3. ⼀维数组传参的本质

4. 冒泡排序

5. ⼆级指针

6. 指针数组

7. 指针数组模拟⼆维数组

1. 数组名的理解

数组名就是数组⾸元素(第⼀个元素)的地址。

这里输入为40,明显与上面不一样。

其实数组名就是数组⾸元素(第⼀个元素)的地址是对的,但是有两个例外:

1.sizeof(数组名),sizeof中单独放数组名,这⾥的数组名表⽰整个数组,计算的是整个数组的⼤⼩, 单位是字节

2. &数组名,这⾥的数组名表⽰整个数组,取出的是整个数组的地址(整个数组的地址和数组⾸元素 的地址是有区别的)

这里我们发现&arr[0]和&arr[0]+1相差4个字节,arr和arr+1相差4个字节,是因为&arr[0]和arr都是 首元素的地址,+1就是跳过⼀个元素。

但是&arr和&arr+1相差40个字节,这就是因为&arr是数组的地址,+1操作是跳过整个数组的。

2. 使用指针访问数组

我们发现,将*(p+i)换成p[i]也是能够正常打印的,所以本质上p[i]是等价于*(p+i)

同理arr[i] 应该等价于*(arr+i),数组元素的访问在编译器处理的时候,也是转换成⾸元素的地址+偏移量求出元素的地址,然后解引⽤来访问的

3. ⼀维数组传参的本质

我们发现函数内部没有求出数组的元素个数。因为:数组名是数组首元素的地址,那么在数组传参 的时候,传递的是数组名,也就是说本质上数组传参本质上传递的是数组首元素的地址。

所以函数形参的部分理论上应该使用指针变量来接收⾸元素的地址

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

4. 冒泡排序

冒泡排序的核心思想就是对比相邻两个数的大小

5.⼆级指针

指针变量存放的地址就叫二级指针。

*ppa通过通过&pa找到pa 还有个*就是 *pa也就是&a。

6. 指针数组

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

7. 指针数组模拟二维数组

parr[i]是访问parr数组的元素,parr[i]找到的数组元素指向了整型⼀维数组,parr[i][j]就是整型⼀维数 组中的元素。

parr数组的首元素就是第一行。

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com