二级指针代码练习题
题目介绍:
在c语言的环境中判断下述代码生成内容:
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指向的是字符串的首元素地址,直到\0。
-
1.printf(“%s\n”, ++cpp)
- cpp先进行自增操作(++cpp)(具体操作顺序可以看运算顺序表)
使cpp-> cp[1]的地址 ,对cpp解应用,得到cp[1]的数据 (这里得到是(c+2,即 c [2])的地址 ) 再对cp[1]解应用,得到输出结果"POINT"
> 注意:
>
> 这里使用的是自增运算符,进行++操作之后cpp 就会一直->cp[1]。
-
*printf(“%s\n”, – * ++cpp + 3);
- 注意这里的运算顺序 ,+3的赋值操作运算优先级是最低的,所以最后运算
先运算*(++cpp),就是cpp指向指向地址再进行++,然后解应用,得到的是 cp[2],即c[1] 的地址
然后进行 *(-- (c + 1) )操作,也就是 * c ,即"ENTER\0"首字母的地址,再进行+3,指向’E’的地址,通过%s输出就是不断的向后读取并 打印,直到\0。
-
*printf(“%s\n”, cpp[-2] + 3);
这里解释cpp[-2]的概念:
我们都直到arr[1]表示的是数组名为arr的数组第一个元素的取值,
并且 数组名表示的就是数组首元素的地址
那么我们可以这样理解: arr[1 ] == *(arr + 1)
同理 cpp[-2] == *(cpp - 2)
*(cpp-2) == cp[0], 因为两个操作中使用的是++操作,cpp目前仍指向cp[2] *cpp[-2] == *cp[0] ,指向的是"ENRER\0"
然后进行+3操作,输出结果为 ER
- printf(“%s\n”, cpp [-1] [-1] + 1);
这串代码我们可以写成* ( *(cpp - 1) - 1)
*cpp - 1 == c+2 , *((c+2)-1) == c[1],指向”NEW\0“的首元素的地址
进行+1操作,指向‘E’;
输出结果:
- POINT
- ER
- ST