C语言函数参数压栈顺序为何是从右到左?
#轉(zhuǎn)載自:http://blog.csdn.net/jiange_zh
上學(xué)期學(xué)習(xí)了匯編語言,并在操作系統(tǒng)實驗中使用了匯編+C語言混合編程,中間也了解了一些C語言與匯編語言的對應(yīng)關(guān)系。
由于匯編語言是底層的編程語言,各種函數(shù)參數(shù)都要直接控制棧進行存取,在混合編程中,要用匯編來調(diào)用C函數(shù),當(dāng)然就要知道參數(shù)的壓棧情況了。
當(dāng)知道C函數(shù)的參數(shù)壓棧順序是從右到左時,我覺得很奇怪,因為大多數(shù)情況下,人們的習(xí)慣是從左到右的,難不成設(shè)計者學(xué)咱們中國古代寫字從右到左的習(xí)慣不成?
當(dāng)時只是記下了這個規(guī)則而已,并沒有去探究這其中的緣由,后來在實驗中自己用匯編實現(xiàn)了printf和scanf函數(shù)的基本功能,嘗到了壓棧從右到左的好處,但是仍然沒有多想。
直到前陣子看斯坦福大學(xué)公開課的時候,老師解釋了一番才恍然大悟! 那么,這是為什么呢? 要回答這個問題,就不得不談一談printf()函數(shù),printf函數(shù)的原型是:printf(const char* format,…) 沒錯,它是一個不定參函數(shù),那么我們在實際使用中是怎么樣知道它的參數(shù)個數(shù)呢?
這就要靠format了,編譯器通過format中的%占位符的個數(shù)來確定參數(shù)的個數(shù)。 現(xiàn)在我們假設(shè)參數(shù)的壓棧順序是從左到右的,這時,函數(shù)調(diào)用的時候,format最先進棧,之后是各個參數(shù)進棧,最后pc進棧,此時,由于format先進棧了,上面壓著未知個數(shù)的參數(shù),想要知道參數(shù)的個數(shù),必須找到format,而要找到format,必須要知道參數(shù)的個數(shù),這樣就陷入了一個無法求解的死循環(huán)了!!
而如果把參數(shù)從右到左壓棧,情況又是怎么樣的?函數(shù)調(diào)用時,先把若干個參數(shù)都壓入棧中,再壓format,最后壓pc,這樣一來,棧頂指針加2便找到了format,通過format中的%占位符,取得后面參數(shù)的個數(shù),從而正確取得所有參數(shù)。 所以,如果不存在…這種不定參的函數(shù),則參數(shù)的壓棧順序無論是從左到右還是從右到左都是沒關(guān)系的
總結(jié)
以上是生活随笔為你收集整理的C语言函数参数压栈顺序为何是从右到左?的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 如何在QT中读取串口数据
- 下一篇: linux下的二进制文件的编辑和查看