多级指针
以二级指针为例
二级指针的由来是 指针数组 的指针形式.
int *p[10]
读取的顺序是
p[10] --> 10个空间的数组 * p[10] --> 这10个空间的数组里面存放的数据都是 指针型的数据 int *p[10] --> 数组里面每个指针指向的空间存放的是int型的数据 int *p[10] --> int **p; p: 指针数组的数组名,也是数组的首地址. *p 数组里面存放的指针 **p 数组里面存放的指针 指向的空间 的内容
二维数组指针:
二维数组: int buf[5][6] = {{1,2,3},{2,3,4},{3,4,5},{4,5,6},{5,6,7}}; 0X00: 1 2 3 0 0 0 0X18: 2 3 4 0 0 0 0X30: 3 4 5 0 0 0 0X48: 4 5 6 0 0 0 0X60: 5 6 7 0 0 0
这是一个 5行 6列 的数组.
在读取的时候,每次读1行,每行有6个元素, 每个元素有int大小.
二位数组的每一行都有一个 行首地址 , 第一行的首地址也是二维数组的首地址.
所以将二维数组看成是许多一维数组的组成,就好理解了.
类比于普通的一维数组:
int a [10]; //a代表的是数组首地址,也是行首地址,从这个地址开始,有10个int大小的数据空间. int (*buf) [6]; //(*buf) == a 表示的是行首地址, 从这个地址开始有 6个 int 大小的数据空间
int (*buf)[6];
读取的顺序是:
*buf 定义一个指针变量,这个变量里面是指针,也就是地址,作为二维数组行首地址 //就好像是一维数组的数组名a
int (*buf)[6]; 以行地址为首,开辟6个int空间.
int (*buf)[6] *(buf+i) //表示 buf[i][0] 的行首地址, *(buf+i)+j //表示 buf[i][j] 的元素地址, *(*(buf+i)+j) //表示 buf[i][j] 的内容
三维数组指针:
int buf[2][3][4]; //三位数组 int (*buf)[3][4] //三维数组指针
所以:
二级指针: int *p[n];
二维数组: int (*p)[n];
原文地址:https://www.cnblogs.com/kmist/p/10080601.html
时间: 2024-10-07 03:24:23