最近学习指针这块遇到了一个自己感觉比较头疼的代码,话不多说先附上代码
#include "stdio.h" #include "stdlib.h" int main() { char *c[] = { "ENTER", "NEW", "POINT", "FIRST" }; char **cp[] = { c + 3, c + 2, c + 1, c }; char ***cpp = cp; printf("%s\n\r", **++cpp); printf("%s\n\r", *--*++cpp + 3); printf("%s\n\r", *cpp[-2] + 3); printf("%s\n\r", cpp[-1][-1] + 1); system("pause"); return 0; }起初看到这个代码确实头疼,但是其实这个题如果画图理解那么会简单好多
然后分析代码 首先char* c[] 是一个指针数组,他里面存放的指针,每个指针都会指向一个字符串 charcp[] 同样也是指针数组,它里面存放的指针,会指向数组c[] char**cpp 是一个三级指针,它指向的是数组cp
分析前两个代码之前,首先强调优先级问题,以及上一个cpp的值会影响下一段代码
分析printf("%s\n\r", **++cpp)第一步:因为优先级的原因,首先计算cpp++,原本他指向的cp[]数组,指向的内容存放地址为0x00EFFD38,由于++所以指向了下一项0x00EFFD3C这一项
第二步:解引用,所以*cpp++的值为0x00EFFD3C,它指向的c[]数组,指向的内容所存放的地址为0x00EFFD58
第三步:再进行解引用,所以**cpp++的值为0x00EFFD58,他的地址所指向的字符串为PIONT
所以输出的结果为PIONT
分析 printf("%s\n\r", *--*++cpp + 3)参考上一个代码,这个代码就不多赘述,第一步计算*++cpp解引用,然后计算 - -++cpp ,此时*- -*++cpp的值为0x00EFFD50,它指向字符串ENTER的首个字母E,此时它还是地址,当+3之后,它指向第四个字母E,最后输出的结果为ER
printf("%s\n\r", *cpp[-2] + 3); 我们来看这个代码,上面我说过,此处的cpp会受到前面的影响所以一开始cpp指向的数组cp[]存放的地址为0x00EFFD40
然后就简单明了,首先计算cpp[-2],cpp[-2]通俗的来说就是-2然后再解引用一下而已, 再解引用,得出地址0x00EFD50,他所指向的字符为FIRST,然后加3,输出的结果为ST
printf("%s\n\r", cpp[-1][-1] + 1);前面我们说过,后边的值会受到前面的影响,有人就会有疑惑,那这样的话,cpp再减一,就不对了,这样的理解是错误的,cpp[-2]我们可以把它当做解引用,并没有做运算,所以cpp的值,还会延续第二个代码结束时的值,好了我们来分析最后一个代码。
和前几个代码大同小异,最后得出的值为EW
附上代码的运行结果图
