程序填空
#include<cstdio>
int main(){
char arr[5][6];
_____________________;
p = arr;
p[2][3] = 'A';//把array[2][3]赋值为'A'
return 0;
}
答案:(*p)[6]
数组指针:顾名思义,其是一个指针,是一个指向数组的一个指针。
举例:int (*p)[4]; char (*p)[4]; 那int *p[4]和int (*p)[4]有什么区别呢? 注意:由上面可知它们是指针,是指向一个大小为4个整型的数组的数组指针。这里*p[4],根据运算优先级,[]运算级高于* 而()操作符和[]优先级相等,从左向右进行运算,因此p先和()里的*结合,所以断定这是指针,然后再和[]结合,就成了数组指针。
指针数组:是一个数组,那是一个什么样的数组呢?是一个存放指针的数组。
举例:int *p[10]; char *p[10]; char **p[10] ; 同上,这里不难看出,它们都是大小为10元素的数组,里面分别存放着元素为 int *,char *,char **类型的指针数组
这里有一道相关的 较经典的面试题,如下:
1 #include<stdio.h> 2 int main() 3 { 4 int a[5][5]; 5 int(*p)[4]; 6 p = a; 7 printf("%d,%p\n", &p[4][2] - &a[4][2], &p[4][2] - &a[4][2]); 8 return 0; 9 }
答案:-4 和 FFFFFFFC
这里画出内存图,解题思路就很清晰了。定义的(*p)[4],p指向一个大小为4个整型的数组,所以将a的地址复制给p时,对p加1,
实际是加上它所指向的类型大小,这里每加1就相当于一次加上4个字节,于是乎我们就不难得出如上答案。
(ps:最后的FFFFFFFC是-4的补码)