多维数组的本质

 

#include<stdio.h>
#include<string.h>

int main()
{
    int a[3][5];
    int i,j;
    int temp = 0;
    for(i = 0; i < 3; i++)
    {
        for(j = 0; j < 5; j++)
        {
            a[i][j] = temp++;
        }
    }
    
    for(i = 0; i < 3; i++)
    {
        for(j = 0; j < 5; j++)
        {
            printf("a[i][j] = %d\n",a[i][j]);
        }
    }
    
    printf("a : %d, a + 1 : %d\n",a,a+1);
    printf("&a : %d, &(a + 1) : %d\n",a,a+1);
    return 0;
}

运行结果:

 

 二维数组指针的步长是20(5*4:5个int型数据*4bit)

 

#include<stdio.h>
#include<string.h>

int main()
{
    int a[3][5];
    int i,j;
    int temp = 0;
    for(i = 0; i < 3; i++)
    {
        for(j = 0; j < 5; j++)
        {
            a[i][j] = temp++;
        }
    }
    
    for(i = 0; i < 3; i++)
    {
        for(j = 0; j < 5; j++)
        {
            printf("a[i][j] = %d\n",a[i][j]);
        }
    }
    
    {
        int (*pArray)[5];
        pArray = a;
        for(i = 0; i < 3; i++)
        {
            for(j = 0; j < 5; j++)
            {
                printf("pArray[i][j] = %d\n",pArray[i][j]);
            }
        }        
    }
    
    printf("a : %d, a + 1 : %d\n",a,a+1);
    printf("&a : %d, &(a + 1) : %d\n",a,a+1);
    return 0;
}

编译通过,运行成功。

 

多维数组名的本质就是数组指针 ==》步长、一维长度。

 

(a+i) 代表第i行的首地址

*(a+i)  代表一级指针,第i行首元素地址

*(a+i)+j 代表a[i][j]元素

 

第一行的地址和第一行的首元素地址是重叠的

 

*(a+i)+j == a[i][j]

 

posted @ 2019-10-16 22:40  王清河  阅读(218)  评论(0编辑  收藏  举报