char *c[], **cp[],char ***cpp详解
前几天在网上看到这道面试题,竟然被这指针搞得一头雾水。真是有些汗颜。
#include "stdio.h"
#include "stdlib.h"
char *c[]={"ENTER","NEW","POINT","FIRST"};
char **cp[]={c+3,c+2,c+1,c};
char ***cpp=cp;
int main(void)
{
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[] 是一个指针数组,里面存放四个char型的指针,每个指针指向一个字符串。假设c在内存中的地址是0x00df7034,内存分布如下
地址 内容
0x00df7034 :00 df 57 b0
0x00DF7038 :00 df 574c
0x00DF703C :00 df 57 44
0x00DF7040 :00 df 57 3c
地址 内容
0x00DF57B0 :45 54 4e 45 00 00 00 52 字符串"ENTER"
0x00DF574c: 00 57 45 4e 字符串"NEW"
0x00DF5744: 4e 49 4f 50 00 00 00 54 字符串"PIONT"
0x00DF573C:53 52 49 46 00 00 00 54 字符串“FIRST”
char **cp[]是一个指向指针的指针数组(二级指针数组),里面每一个数组元素是一个二级指针。假设cp在内存中的地址为
0x00df7044,内存分布如下:
地址 内容
0x00DF7044 :00 df 70 40
0x00DF7048 :00 df 70 3c
0x00DF704C :00 df 70 38
0x00DF7050 :00 df 70 34
char ***cpp是一个三级指针,而cp[]以数组名使用用时,也是一个3级指针。
因此:
char ***cpp=cp;之后cpp等于0x00df7044;
1. printf("%s\n\r",**++cpp);
先说**++cpp表达式,运算从右至左;++cpp等于cpp+sizof(char ***)=0x00df7048;
*++cpp=*(0x00df7048)=0x00df703c;
**++cpp=*(0x00df703c)=0x00df5744;
printf输出"PIONT";
2. printf("%s\n\r",*--*++cpp+3);
*--*++cpp+3运算,先运算*--*++cpp
同理++cpp=0x00df704c;
--*++cpp=0x00df7038-sizeof(char **)=0x00df7034
0x00df7034+3=0x00df7037
输出"ER"
3. printf("%s\n\r",*cpp[-2]+3);
*cpp[-2]+3先算*cpp[-2]
cpp[-2]=cpp+-2*sieof(cpp[i])=0x00df704c-8=0x00df7044
*cpp[-2]+3=0x00df573+3
输出"ST"
4. printf("%s\n\r",cpp[-1][-1]+1);
cpp[-1][-1]=*(*(cpp+-1)+-1)=*(*(0x00df704c-4)-4)
输出“EW”