深入理解指针(2)

avatar
作者
猴君
阅读量:0

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数组的首元素就是第一行。

广告一刻

为您即时展示最新活动产品广告消息,让您随时掌握产品活动新动态!