多维数组的本质

#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]

猜你喜欢

转载自www.cnblogs.com/wanghao-boke/p/11688948.html