C语言初探 之 printf压栈顺序

写在篇头:

在不同的编译器下结果不同,本例测试的环境为 devcpp5.3.0.1 。   

——————————————————————————————————————————————————————————————————————

  先看一段代码,猜猜会是什么输出:

x=1;   printf("%d %d\n",x,x++);
x=1;   printf("%d %d\n",x++,x);
x=1;   printf("%d %d %d\n",x,x++,x);
x=1;   printf("%d %d %d %d\n",x,++x,x++,x);
     如是~:
2 1
1 2
2 1 2
3 3 1 3

      看到这里,你会发现,有时看起来是从左往右算,有时候是从右往左算,有时候还是从乱序算。。是不是有些郁闷呢。

      其实,在处理printf时,压栈顺序为从右往左,也就是说从右往左的计算(“计算”不等于“输出”)。

      在计算时,遇到x++会记录此时的x的值作为最后的输出结果。遇到x和++x的时候则不会将此时的计算结果作为最终的输出,只会修改x的值,在最终输出的时候都输出x的值(所以++x和x的结果总是一样的)。

      为什么会是这个样子呢?参见某高手解释吧:

      对于a++的结果,是有ebp寻址函数栈空间来记录中间结果的,在最后给printf压栈的时候,再从栈中把中间结果取出来;而对于++a的结果,则直接压寄存器变量,寄存器经过了所有的自增操作。 (来源:http://www.zzzj.com/html/20090609/71613.html)


[小试身手]

a=1; 
printf("%d %d %d %d %d %d\n",a++, ++a, a++, ++a, a++, ++a );

答案:[ 6 7 4 7 2 7 ]

(选中答案框看结果,你懂的~)

全部评论

相关推荐

身边的人都在收获,我却还在原地踏步,到底该怎么办啊!每次看到他们的好消息,我都想放弃,心里不停地问自己:到底该怎么才能找到一份工作呢?这种无力感让我想要彻底摆烂,真的很想知道,别人是怎么做到的。有没有人分享一下经历呢?我想学习一下啊走出这样的日子。
鼗:秋招其实是运气>实力的一场竞技游戏,除非实力很强(学历和技术)。大多数人都是半斤八两,看面试官和HR以及简历被曝光的概率罢了,有些时候你可能运气差一点或者说面试官不太友好也或者说你确实准备的不够好之类的,这些都是可能发生的事情。我觉得能做的事情是不比较、不气馁、在面试前多看一点面试的时间冷静一点自信一点,大大方方面试,给自己多一点时间去求职。我这样说不是站着说话不腰疼,我是想说你的offer还在路上,你也值得在这些困难之后得到你较为理想的offer,请你继续加油,保持乐观,积极打败你现在的困难
点赞 评论 收藏
分享
11-06 15:41
门头沟学院 Java
等大佬释放捡剩菜,还有机会吗
普通上班族1:0offer+0池子。
点赞 评论 收藏
分享
offer多多的六边形战士很无语:看了你的博客,感觉挺不错的,可以把你的访问量和粉丝数在简历里提一下,闪光点(仅个人意见)
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务