以下代码和结果是使用vs2022进行相关代码运行的
题目如下:
这里解释一下,原题是没有加(char*)的,因原代码在vs2022中会报错,这里强制类型转换解决了这个问题,对代码最终的运行结果无影响。
好的,我们的PK正式开始
首先用画图分析法,进行初步题目的分析
由此我们可以清楚的看到各级指针的指向情况
补充说明:一级指针char*c[]中存储的是字符串首字母在内存中的地址
分析第一小题:printf("%s\n",**++cpp)
根据优先级,先计算++cpp,指针cpp指向c+2,再计算*++cpp,进行第一次解引用,得到c+2,指针cp(1)指向c(2),计算**++cpp,进行第二次解引用,得到c(2)中的内容,也就是字符串首字母p的地址,最后printf打印,根据首字母的地址找到字符串POINT,具体过程如上动图演示
printf 结果是POINT
此时各级指针指向情况如下:因为++cpp,代码printf("%s\n",**++cpp)运行后,cpp中的地址已经发生改变,指向c+2
这个“男人”变了,它变心了,它的心里现在装着的是c+2
分析第二小题:printf("%s\n",*--*++cpp+3)
根据优先级,先计算++cpp,指针cpp在第一小题的基础上指向c+1,进行第一次解引用,得到c+1,再计算--*++cpp,得到c ,此时指针cp指向c(0),进行第二次解引用,得到c(0)中的地址,即字符串首字母E的地址,最后+3,得到字符串中第二次出现的E的地址,printf打印,得到结果ER,具体过程如上动图演示
printf 结果是ER
补充说明:
字符串的地址在内存中是连续变化的
此时各级指针指向情况如下:执行完代码printf("%s\n",*--*++cpp+3),因为++cpp的运算,改变了指针cpp指向的内容 ,cpp指向c
没错,它又变了
分析第三小题:printf("%s\n",*cpp[-2]+3)
这里printf("%s\n",*cpp[-2]+3)相当于printf("%s\n",**(cpp-2)+3),两者是一样的
将原代码简化成printf("%s\n",**(cpp-2)+3),更易于理解
原指针cpp 指向c,先计算(cpp-2),指针cpp 指向c+3,进行第一次解引用,得到c+3,c+3指向c(3),进行第二次解引用,得到c(3)中的地址,即字符串首字母F的地址,最后+3,得到字母S的地址,打印得到结果ST(与第二小题计算方式相似)具体过程如上动图演示
printf 结果是ST
此时各级指针指向情况如下:执行完第三小题的代码没有改变指针cpp指向的内容
分析第四小题:printf("%s\n",cpp[-1][-1]+1)
这里printf("%s\n",cpp[-1][-1]+1)相当于printf("%s\n",*(*(cpp-1)-1)+1),两者是一样的
代码简化成printf("%s\n",*(*(cpp-1)-1)+1)更容易理解 先计算(cpp-1),指针cpp 指向c+2,进行第一次解引用,得到c+2,再计算*(cpp-1)-1,指针指向c(1),进行第二次解引用,得到字符串首字母N的地址,最后+1,得到字母E的地址,printf打印,得到结果EW,(与第二小题计算方式相似)具体过程如上动图演示
printf 结果是EW
综上运行结果应该为
POINT
ER
ST
EW
vs2022运行验证结果
结果无误!!!!
在处理指针的相关问题时,通过画图分析的方法,可以让指针的指向关系更加清晰明了,思路清晰了,事倍功半!!!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)