前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >【C 语言】数组 ( 多维数组本质 | 步长角度 理解 多维数组本质 )

【C 语言】数组 ( 多维数组本质 | 步长角度 理解 多维数组本质 )

作者头像
韩曙亮
发布2023-03-29 21:42:08
5.6K0
发布2023-03-29 21:42:08
举报

文章目录

一、从 步长角度 理解 多维数组本质


声明一个二维数组 ;

代码语言:javascript
复制
    // 声明一个多维数组
    int array[2][3];

二级指针 :

array + i 表示第 i 行的地址 , 整个第 i 行地址 , array 是 二级指针 ;

array + i 的步长是 一维数组 的大小 , 也就是

12

字节 ;

一级指针 :

*(array + i) 表示第 i 行的首元素地址 , *二级指针 是 一级指针 ;

*(array + i) 使用 * 取出来的是 一级指针变量 , 这个 一级指针变量 就是 一维数组 , 该变量是 数组首地址 , 每次增加的步长是 数组元素的大小 , 该数组元素类型是 int 类型 , 步长

4

字节 ;

一维数组的某个元素 :

*(array + i) + j 表示第 i 行的第 j 个元素的地址 , 是一个元素的地址 , 等同于 &array[i][j] ;

上面的 j 的步长是 每个 int 类型的大小 ,

4

字节 ;

二维数组 , 第一行地址 与 第一行首元素地址 值相同 ;

数组首元素地址 和 数组地址 :

  • array 表示 数组首元素地址 , 每次累加步长 , 是 数组元素的内存大小 ; ( 常用 )
  • &array 表示 数组地址 , 每次累加步长是 整个数组的内存大小 ; ( 这种情况不常用 )

二、代码示例


代码示例 :

代码语言:javascript
复制
#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;
}

执行结果 :

代码语言:javascript
复制
array = 6422200, array + 1 = 6422212
*(array) = 6422200, *(array) + 1 = 6422204
*(array + 1) = 6422212, *(array + 1) + 1 = 6422216
请按任意键继续. . .
在这里插入图片描述
在这里插入图片描述
本文参与?腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2021-11-29,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客?前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与?腾讯云自媒体分享计划? ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 文章目录
  • 一、从 步长角度 理解 多维数组本质
  • 二、代码示例
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
http://www.vxiaotou.com