文章目录
一、从 步长角度 理解 多维数组本质
二、代码示例
一、从 步长角度 理解 多维数组本质
声明一个二维数组 ;
// 声明一个多维数组 int array[2][3];
二级指针 :
array + i 表示第 i 行的地址 , 整个第 i 行地址 , array 是 二级指针 ;
array + i 的步长是 一维数组 的大小 , 也就是 12 1212 字节 ;
一级指针 :
*(array + i) 表示第 i 行的首元素地址 , *二级指针 是 一级指针 ;
*(array + i) 使用 * 取出来的是 一级指针变量 , 这个 一级指针变量 就是 一维数组 , 该变量是 数组首地址 , 每次增加的步长是 数组元素的大小 , 该数组元素类型是 int 类型 , 步长 4 44 字节 ;
一维数组的某个元素 :
*(array + i) + j 表示第 i 行的第 j 个元素的地址 , 是一个元素的地址 , 等同于 &array[i][j] ;
上面的 j 的步长是 每个 int 类型的大小 , 4 44 字节 ;
二维数组 , 第一行地址 与 第一行首元素地址 值相同 ;
数组首元素地址 和 数组地址 :
array 表示 数组首元素地址 , 每次累加步长 , 是 数组元素的内存大小 ; ( 常用 )
&array 表示 数组地址 , 每次累加步长是 整个数组的内存大小 ; ( 这种情况不常用 )
二、代码示例
代码示例 :
#include <stdio.h> #include <stdlib.h> #include <string.h> /** * @brief main 多维数组名本质 * @return */ int main() { // 声明一个 二维数组 int array[2][3]; // 二维数组首元素地址 , 每次 + 1 步长是 12 字节 printf("array = %d, array + 1 = %d\n", array, array + 1); // *(array) 是二维数组首元素 , 取出来是 一维数组 // *(array) + 1 是 一维数组 首元素地址 + 1 , 每次增加 4 字节 printf("*(array) = %d, *(array) + 1 = %d\n", *(array), *(array) + 1); // array + 1 是二维数组的第二个元素地址 , *(array + 1) 是第二个元素的值 是 一维数组 // *(array + 1) + 1 是一维数组 首地址 + 1 , 增加了一个数组元素 , 步长增加 4 字节 printf("*(array + 1) = %d, *(array + 1) + 1 = %d\n", *(array + 1), *(array + 1) + 1); // 命令行不要退出 system("pause"); return 0; }
执行结果 :
array = 6422200, array + 1 = 6422212 *(array) = 6422200, *(array) + 1 = 6422204 *(array + 1) = 6422212, *(array + 1) + 1 = 6422216 请按任意键继续. . .