一道有趣的指针笔试题
注:博主认为,如果想要做对并理解这一题的有关知识点,读者有必要对指针有一个较为全面且深刻的认识,如果小伙伴们对指针还不是太熟悉,建议先看看一篇带你玩转C语言指针:从入门到精通
题目
#include<stdio.h>
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;
}
解析
- c是一个指针数组,存放的是4个字符串常量的首元素地址
- cp也是一个指针数组,其存放的是指针数组c中每个指针的地址
- cpp是一个三级指针,其指向的是指针数组cp的首元素
- 故可以画出示意图:
第一题:
**++cpp
,先计算++cpp
,则此时cpp指向的是指针数组cp的第二个元素,进行第一次解引用得到的就是cp的第二个指针,其指向的是指针数组c的第三个元素,再进行一次解引用得到的就是数组c的第三个元素,其指向的时字符串‘POINT’的首地址,故打印POINT
第二题:
*-- * ++cpp + 3
,由于第一题的++cpp
,第二题++cpp
过后,cpp指向的就是指针数组的第三个元素,解引用后得到cp的第三个元素,其指向指针数组c的第二个元素,对cp的第三个元素进行前置- -操作,是其指向数组c的第一个元素,解引用后得到指针数组c的第一个元素,其指向字符串“ENTER”的首元素‘E’,最后再+3,变成指向第四个元素‘E’,最后打印ER
第三题:
*cpp[-2] + 3
,我们可以将其改成*(*(cpp - 2)) + 3
,cpp减二再解引用得到的就是指针数组cp的第一个元素,其指向指针数组c的最后一个元素,解压以后得到的就是指向字符串‘’FIRST‘’首元素的指针,再加三,得到的就是字符串“FIRST”的第四个元素,故打印ST
第四题:
cpp[-1][-1] + 1
,可以改写为*(*(cpp - 1) - 1) + 1
。注意,第三题cpp - 2并没有实际移动cpp的指向,此时cpp仍指向数组cp的第三个元素,cpp - 1再解引用得到的是数组cp的第二个元素,继续减一再解引用,得到的便是数组c的第二个元素,该元素指向的是字符串“NEW”首元素的地址,加1后就是第二个元素的地址,故打印EW