【C语言】二维数组在内存中的存储方式

二维数组实际在内存中的存储方式
这里写图片描述

提示:二维数组也是按照像一维数组那样的存储.

注意:如何证明:通过指针来进行访问每一个元素*(*a+1)
1.*a 表示将一个行地址变成该行的首地址(即一个具体元素的地址))
2.&a[0][1]表示讲一个具体的元素地址 提升为该行的行地址(*与&转换关系相反)

#include<stdio.h>
#include<windows.h>
int main()
{
    int a[3][4];
    int i, j;
    for (i = 0; i < 3; i++)
    {
        for (j = 0; j < 4; j++)
        {
            a[i][j] = i * 4 + j;
        }
    }
    for (i = 0; i < 12; i++)
    {
        printf("a[%d]=%d\n", i,*(*a+i));
    }

    system("pause");
    return 0;

}

这里写图片描述


版权声明:本文为lizhidefengzi原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。