一道面试题:
已知 inta[3][4];则下列能表示a[1][2]元素值的是()
A、*(*(a+1)+2) B、*(a+1+2) C、(&a[0]+1)[2] D、*(a[0]+1)
这题似乎一看应该选 A,C 两个项。但正确的结果只有 A;
C中的写法通不编译。写成这样:(int*)(&a[0] + 1)[2] 可通过编译,结果也是正确的。
让我们来分析一下,为什么 (&a[0] + 1)[2] 编译出错。
首先,&a[0] + 1 应该是一个数组的地址,应该用一个数组指针去保存这个地址,确切地说:
int (*pArray) [4] = &a[0] + 1;//ok
pArray[2]//no,因为 pArray 是一个数组指针,而编译器遇到 pArray[2] 会这样看待:*(pArray + 2)
//而 pArray 指代的是数组,于是编译器会报如下错误:cannot convert from 'int [4]' to 'int'
正确的通过数组指针得到 a[1][2] 的方法是:
(*pArray)[2];// *pArray 先对数组地址指针解引用,得到数组,再通过 [2] 得到结果。
我们还遗留一个问题没有回答,为什么 ((int*)(pArray))[2] 也可以得出结果呢?下面一幅图对原理予以解释。