指针和数组是面试的时候遇到面试官问的频数最多的问题,但从事实上来说,他俩之间其实没多大关系,只不过数组有时候会隐式转成指针。
先不要头疼,下面这道题如果清楚了,那么指针和数组基本就难不到你了!
先来看一下这个经典的指针数组笔试题目,如下代码块:
int main()
{
char *c[] = { "ENTER", "NEW", "POINT", "FIRST" };
char **cp[] = { c + 3, c + 2, c + 1, c };
char ***cpp = cp;
printf("%s\n", **++cpp);
printf("%s\n", *--*++cpp + 3);
printf("%s\n", *cpp[-2] + 3);
printf("%s\n", cpp[-1][-1] + 1);
return 0;
}
char *c[ ] = { "ENTER", "NEW", "POINT", "FIRST" };这是一个指针数组,每个元素指向相应的字符串的首字符的地址 。
char **cp[] = { c + 3, c + 2, c + 1, c };这是一个二级指针数组,每个元素指向“指针”数组c 的对应空间的地址。
char ***cpp = cp;这是一个三级指针,指向“二级指针”数组cp的首地址 。
画图表示的话就是这样子:
再来看四个问题:
1)printf("%s\n",**++cpp);
2)printf("%s\n",*--*++cpp+3);
3)printf("%s\n",*cpp[-2]+3);
4)printf("%s\n",cpp[-1][-1]+1);
还是用图形来分析:
输出结果如下: