概述
转载自:https://blog.csdn.net/kzzhr/article/details/8482657
先看一段代码,猜猜会是什么输出:
x=1; printf("%d %dn",x,x++);
x=1; printf("%d %dn",x++,x);
x=1; printf("%d %d %dn",x,x++,x);
x=1; printf("%d %d %d %dn",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)
从右往左入栈,x或++x只改变x的值,x++确定最后此位置的输出,x最后计算完后,x和++x位置的值都是此时x的值。
a=1;
printf("%d %d %d %d %d %dn",a++, ++a, a++, ++a, a++, ++a );
答案:[ 6 7 4 7 2 7 ]
最后
以上就是踏实芒果为你收集整理的printf压栈顺序的全部内容,希望文章能够帮你解决printf压栈顺序所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复