首先来看一道指针的题,答案如下
#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是指针数组,用来存储地址的指针,又因为是char类型的,所以只能存储每个单词的是首元素地址,CP是也是个指针数组,不过它只能存储地址的地址,CPP就是三维指针,用来存放二位指针的地址,我们用图来解释一下,最开始的情况就是这样的
注意这里的陷阱++cpp这里的cpp要移动,到下一个位置
所以这里这里一次解引用找到的是CP的第二个位置然后再解引用,找到的是C的倒数第二个位置,那么打印出来的就是POINT。
接下来这个有一点复杂,因为优先级的问题+3最后处理。
目前是这样的,++cpp,cpp到这个位置
解引用找到C+1这个地方里面的内容,就是NEW的地址,然后自减,就成了这样
再次解引用,就是找到了E的地址,+3往后移动3个字节,找到T后面的E,输出的就是ER
接着往下看,这里CPP没有自增或者自减,所以我用CPP*来代替目前地址位置。
最后一个如图