#include
創(chuàng)新互聯(lián)長期為成百上千客戶提供的網(wǎng)站建設(shè)服務(wù),團(tuán)隊(duì)從業(yè)經(jīng)驗(yàn)10年,關(guān)注不同地域、不同群體,并針對不同對象提供差異化的產(chǎn)品和服務(wù);打造開放共贏平臺,與合作伙伴共同營造健康的互聯(lián)網(wǎng)生態(tài)環(huán)境。為新會企業(yè)提供專業(yè)的成都做網(wǎng)站、網(wǎng)站設(shè)計(jì),新會網(wǎng)站改版等技術(shù)服務(wù)。擁有10余年豐富建站經(jīng)驗(yàn)和眾多成功案例,為您定制開發(fā)。
void
foo(int
x,
int
y,
int
z)
{
printf("x
=
%d
at
[%x]n",
x,
x);
printf("y
=
%d
at
[%x]n",
y,
y);
printf("z
=
%d
at
[%x]n",
z,
z);
}
int
main(int
argc,
char
*argv[])
{
foo(100,
200,
300);
return
0;
}
運(yùn)行結(jié)果:
x
=
100
at
[bfe28760]
y
=
200
at
[bfe28764]
z
=
300
at
[bfe28768]
c程序棧底為高地址,棧頂為低地址,因此上面的實(shí)例可以說明函數(shù)參數(shù)入棧順序的確是從右至左的。可到底為什么呢?查了一直些文獻(xiàn)得知,參數(shù)入棧順序是和具體編譯器實(shí)現(xiàn)相關(guān)的。比如,pascal語言中參數(shù)就是從左到右入棧的,有些語言中還可以通過修飾符進(jìn)行指定,如visual
c++.即然兩種方式都可以,為什么c語言要選擇從右至左呢?
進(jìn)一步發(fā)現(xiàn),pascal語言不支持可變長參數(shù),而c語言支持這種特色,正是這個(gè)原因使得c語言函數(shù)參數(shù)入棧順序?yàn)閺挠抑磷蟆>唧w原因?yàn)椋篶方式參數(shù)入棧順序(從右至左)的好處就是可以動態(tài)變化參數(shù)個(gè)數(shù)。通過棧堆分析可知,自左向右的入棧方式,最前面的參數(shù)被壓在棧底。除非知道參數(shù)個(gè)數(shù),否則是無法通過棧指針的相對位移求得最左邊的參數(shù)。這樣就變成了左邊參數(shù)的個(gè)數(shù)不確定,正好和動態(tài)參數(shù)個(gè)數(shù)的方向相反。
因此,c語言函數(shù)參數(shù)采用自右向左的入棧順序,主要原因是為了支持可變長參數(shù)形式。換句話說,如果不支持這個(gè)特色,c語言完全和pascal一樣,采用自左向右的參數(shù)入棧方式
void
swap(int
*p1,int
*p2)
/*利用指針作為函數(shù)參數(shù)*/
{
int
*t;
t=p1;
p1=p2;
p2=t;
}
中
是先把指針的地址傳給形參,即
p1=a;p2=b而函數(shù)指改變了p1、p2,即
p1=b;p2=a;但是*a和*b的值并沒有改變
就是說只改變了形參但實(shí)參還是原來的
下面的函數(shù)交換了*a和*p的值
所以輸出結(jié)果就變了
C中,函數(shù)指針也就是一個(gè)int類型的數(shù)值,你可以任意變換使用.但是,一旦變換后程序能否正確執(zhí)行的責(zé)任在于你自己的設(shè)計(jì)思路.
當(dāng)然可以,最典型的就是printf函數(shù)了,這個(gè)函數(shù)采用的就是可以改變形參數(shù)量的方法,百度上搜索:“C語言不定參數(shù)”就可以查到相關(guān)信息了C語言中的不定參數(shù)