學(xué)號:19021211263
#include<stdio.h>
int main()
{
int A[2][3] = {
{1,2,3},
{4,5,6}
};
printf("=========================\n");
printf("A[0][1]:%d\n",A[0][1]);
printf("*(*(A+0)+1):%d\n",*(*(A+0)+1));
printf("=========================\n");
printf("&A[1][0]:%d\n",&A[1][0]);
printf("*(A+1):%d\n",*(A+1));
printf("=========================\n");
printf("**(A+1):%d\n",**(A+1));
printf("**((int (*)[1])A+1):%d\n",**((int (*)[1])A+1));
return 0;
}
結(jié)果:
=========================
A[0][1]:2
*(*(A+0)+1):2
=========================
&A[1][0]:6487612
*(A+1):6487612
=========================
**(A+1):4
**((int (*)[1])A+1):2
分析:
-
A[0][1]:常規(guī)的二維數(shù)組索引 -
*(*(A+0)+1)):利用雙重指針來對二維數(shù)組進(jìn)行索引,這里的A應(yīng)該是一個int ()[3]數(shù)組指針類型的變量,*(A+0)就是一個*int ***類型的變量,所以這里和A[0][1]的結(jié)果是一樣的。 -
&A[1][0]:第二行第一列數(shù)據(jù)的地址 -
*(A+1):同第二點(diǎn),這里A是一個int ()[3]數(shù)組指針類型的變量,故A+1指向第二行,且A+1仍是一個int ()[3]**數(shù)組指針類型的變量,取地址后就是第二行行首的地址 -
**(A+1):同理,A是一個int ()[3]數(shù)組指針類型的變量,A+1指向第二行*,兩次取地址后就是元素A[1][0] -
**((int (*)[1])A+1)):這里利用強(qiáng)制類型轉(zhuǎn)化將A的類型由int ()[3]數(shù)組指針類型轉(zhuǎn)化為int ()[1],故A+1指向第二列,且A+1仍是一個int ()[1]*數(shù)組指針類型的變量,兩次取地址后就是元素A[0][1]
更多有趣內(nèi)容歡迎訪問我的個人博客。