發布時間:2011-09-16 共1頁
在C/C++中,對函數參數的掃描是從后向前的。C/C++的函數參數是通過壓入堆棧的方式來給函數傳參數的(堆棧是一種先進后出的數據結構),最先壓入的參數最后出來,在計算機的內存中,數據有2塊,一塊是堆,一塊是棧(函數參數及局部變量在這里),而棧是從內存的高地址向低地址生長的,控制生長的就是堆棧指針了,最先壓入的參數是在最上面,就是說在所有參數的最后面,最后壓入的參數在最下面,結構上看起來是第一個,所以最后壓入的參數總能被函數找到,因為它就在堆棧指針的上方,printf第一個被找到的參數就是那個字符指針,就是雙引號括起來的那一部分,函數通過判斷字符串里控制參數的個數來判斷參數個數及數據類型,通過這些就可算出個數據需要的堆棧指針的偏移量了,下面給出printf("%d,%d",a,b);(其中a,b都是int型的)匯編代碼
.section .data string out=“%d,%d”
push b;
push a;
push $out
call printf
看到沒參數是最后的先壓如,最先的后壓入,參數控制的那個字符串常量最后壓入,所以這個常量總是能被找到。