對多維陣列的理解
阿新 • • 發佈:2019-01-05
1.我們知道陣列名就是指標常量。下面我們來介紹陣列名的作用和用法
A. int a[3];
這是一個一維陣列
a:表示陣列首元素的地址。0x1000
&a:表示對一維陣列的陣列名取地址等於陣列的地址。0x1000
B. int a[2][2];
這是一個二維陣列
a:表示首個一維陣列的地址。a-->0x1000
a+i:表示第i+1個一維陣列的地址。a+0-->0x1000 a+1-->0x1008
*(a+i):表示第i+1個一維陣列首個元素的地址。*(a+0)-->0x1000
*(a+i)+j:表示第i+1個一維陣列的第j+1個元素的地址。*(a+0)+1-->0x1004
*(*(a+i)+j):表示第i+1個一維陣列的第j+1個元素的值。*(*(a+0)+0)-->1
&a:表示陣列的地址。&a-->0x1000
C. int a[3][2][2];
這是一個三維陣列
a:表示首個二維陣列的地址。
a+i:表示第i+1個二維陣列的地址。
*(a+i):表示第i+1個二維陣列首個一維陣列的地址。
*(a+i)+j:表示第i+1個二維陣列的第j+1個一維陣列的地址。
*(*(a+i)+j):表示第i+1個二維陣列的第j+1個一維陣列首個元素的地址。
*(*(a+i)+j)+k:表示第i+1個二維陣列的第j+1個一維陣列的第k+1個元素的地址。
*(*(*(a+i)+j)+k):表示第i+1個二維陣列的第j+1個一維陣列的第k+1個元素的值。
2.多維陣列在記憶體中的儲存也是一維陣列,抽象成多維陣列只是為了方便理解多維陣列。
執行結果為:#include <stdio.h> int main() { int a[2][2] = {1,2,3,4}; int *p = a; //指標不相容,但是隻列印陣列的地址存放的值! int i; int j; for(i = 0; i < 2; i++) { for(j = 0; j < 2; j++) { printf("a[%d][%d] = %p\n", i, j, &a[i][j]); //列印地址 } } for(i = 0; i < 4; i++) { printf("a[%d] = %d\n", i, a[i]); //列印陣列存放的值 } return 0; }
[[email protected] 0725]# ./a.out
a[0][0] = 0xbfdc45c8
a[0][1] = 0xbfdc45cc
a[1][0] = 0xbfdc45d0
a[1][1] = 0xbfdc45d4
a[0] = 1
a[1] = 2
a[2] = 3
a[3] = 4
由執行結果可知,陣列分配的是一塊連續的記憶體。並且陣列的儲存方式是很多個一維陣列連線成一個大的一維陣列。