一、数组指针
数组指针,顾名思义就是指向一维数组的指针;
看一下代码
b是一个2*2的二维数组,即存放两个一维数组;
p是指向数组的指针,步长为2,即可以指向两个一维数组;
#include <stdio.h>
#include <stdlib.h>
int main(void) {
int b[2][2] = { 5,4,8,9};
int(*p)[2]; //定义一个数组指针,指针步长为2个int即8位。
p = b; //让p指向二维数组b。
return 0;
}
通过解析二维数组在内存中的存储情况,可以更好的理解数组指针;对于b数组,数据类型为整型,存放数据元素的个数为4个,所以内存中将会开辟4*sizeOf(int)连续内存空间来存储元素(按行存储);
下图为元素的存储情况:
上图中变量前加*就是取出其中所存放值;
从图中可知,如果想取出第i行的第j个元素的值;
1、p+i ,指向第i行的第一个元素;
2、*(p+i):取出值;,此时位第i个一维数组的收地址
3、*(p+i)+j;地址值加j,指向第i行第j个元素;
4、 *(*(p+i)+j):取出值;
注:其中p换成a也是成立的;
二、指针数组
指针数组:首先是有个数组,该数组中存放的是指针变量;