求下列代码的输出结果:
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;
}
输出结果为:POINT ER ST EW
一开始的指向如下图所示:
首先看 **++cpp,**++cpp前置++,先使用后++,所以cpp指向位置发生了改变:
即此时cpp指向了上图所示位置,对其解引用后为二级指针cp[1]的内容c+2,再对c+2进行解引用,就可以得到指向POINT中P的一级指针char*。
再看*--*++cpp+3,拆分的来看:++cpp依旧表示此时先++后使用,则此时指向的地址为:
(注:上面的++cpp已经对cpp产生改变了)
对++cpp进行解引用,就得到了cp[2]的内容c+1,而再--cp[2],即对cp[2]中的内容进行--,即(c + 1)--,则此时变化为:再对其解引用,得到指向ENTER中E的一级指针char*,而对char* + 3就使得该一级指针指向E,所以最终以%s打印时得到的结果为ER。(纯粹的+3而非++没有使该一级指针发生改变)
再看*cpp[-2]+3,cpp[-2]等价于*(cpp-2),即cpp[-2]得到的是cp[0]的内容,对其解引用得到指向FIRST中F的一级指针char*,再对其+3,则该一级指针指向了FIRST中的S,所以最终以%s打印时得到的结果为ST。(cpp[-2]并没有对cpp的实际指向发生改变)
最后看cpp[-1][-1]+1,等价于*(*(cpp-1)-1)+1,首先cpp-1解引用得到cp[1]的内容c+2,对其-1则为c+1,对c+1解引用得到指向NEW中N的一级指针char*,再对该一级指针+1,便指向了E,所以最后以%s打印时得到的结果为EW。