二維數組、行指針、指針數組、二級指針數組
看到這個標題是否是很頭大,那麼來看段簡單的程序:測試
/************************************* * 文件名稱:pointer.c * 文件描述:測試二維數組,指針數組,行指針 與二級指針 * 文件做者:by Wang.J,in 2013.11.07 * 文件版本:1.0 * 修改記錄: **************************************/ #include <stdio.h> int main(void) { int i = 0, j = 0; int a[4][3] = {{0,1,2}, {3,4,5}, {6,7,8}, {9,10,11}}; int *pa[4]; //指針數組, 數據類型 *變量名[n] int **pp; //二級指針, 數據類型 **變量名 int (*p)[3]; //行指針, 數據類型 (*變量名)[n] pa[0] = a[0]; pa[1] = a[1]; pa[2] = a[2]; pa[3] = a[3]; pp = pa; p = a; printf("a[4][3]:\n"); for (i = 0; i < (sizeof(a)/sizeof(a[0])); i++) { for (j = 0; j < (sizeof(a[0])/sizeof(a[0][0])); j++) { printf("%d\t", a[i][j]); } printf("\n"); } printf("\n\n"); printf("*pa[4]:\n"); for (i = 0; i < (sizeof(a)/sizeof(a[0])); i++) { for (j = 0; j < (sizeof(a[0])/sizeof(a[0][0])); j++) { printf("%d\t", *(pa[i]+j)); } printf("\n"); } printf("\n\n"); printf("**pp:\n"); for (i = 0; i < (sizeof(a)/sizeof(a[0])); i++) { for (j = 0; j < (sizeof(a[0])/sizeof(a[0][0])); j++) { printf("%d\t", *((*pp+i*3)+j)); /* * 上面的3是(sizeof(a)/sizeof(a[0]))的結果,我嫌太長直接寫了3,各位注意! * 也能夠可使用*(pp[i]+j)的形式,不過上面的形式更好理解一點 */ } printf("\n"); } printf("\n\n"); printf("(*p)[3]:\n"); for (i = 0; i < (sizeof(a)/sizeof(a[0])); i++) { for (j = 0; j < (sizeof(a[0])/sizeof(a[0][0])); j++) { printf("%d\t", *(*(p+i)+j)); } printf("\n"); } printf("\n\n"); return 0; }
看看執行結果spa
結論很簡單:.net
a[i][j] == pp[i][j] == *(*(pp+i)+j) == *(pa[i]+j) == *(*(p+i)+j)指針
還有一個結論:code
*(p+i) = p[i];你們可使用這個結論簡化上面的式子.blog
a[i][j] == pp[i][j] == pa[i][j] == p[i][j]ip