通常在C語言中,一個完整的項目程序是不可能在一個函數(shù)中實現(xiàn)所有的功能。而是由若干功能不同的函數(shù)來實現(xiàn),并且函數(shù)之間會存在互相調(diào)用的情況。
成都創(chuàng)新互聯(lián)是一家專業(yè)提供曲靖企業(yè)網(wǎng)站建設(shè),專注與網(wǎng)站建設(shè)、做網(wǎng)站、H5建站、小程序制作等業(yè)務(wù)。10年已為曲靖眾多企業(yè)、政府機(jī)構(gòu)等服務(wù)。創(chuàng)新互聯(lián)專業(yè)的建站公司優(yōu)惠進(jìn)行中。
函數(shù)是C語言的基本組成元素,如果你要想實現(xiàn)函數(shù)的功能,那么你就必須學(xué)會正確調(diào)用函數(shù)。當(dāng)我們調(diào)用一個函數(shù)時,需要明確函數(shù)名和實參列表。實參列表中的參數(shù)可以是常量、變量、表達(dá)式或者空,并且各參數(shù)之間要使用英文逗號分隔開來。
在數(shù)學(xué)運算中,會遇到計算多個連續(xù)自然數(shù)之間的和的情況。例如要計算1~n之間自然數(shù)之和,就需要先計算1加2的結(jié)果,用這個結(jié)果加3再得到一個結(jié)果,用新得到的結(jié)果加4,以此類推,直到用1~(n-1)之間所有數(shù)的和加n。
在程序開發(fā)中,要想完成上述功能,就需要使用函數(shù)的遞歸調(diào)用,所謂的遞歸調(diào)用就是函數(shù)內(nèi)部調(diào)用自身的過程。需要注意的是,遞歸必須要求有結(jié)束條件,不然就會陷入無限遞歸的狀態(tài),永遠(yuǎn)無法結(jié)束調(diào)用。接下來通過一個計算自然數(shù)之和的案例來學(xué)習(xí)遞歸調(diào)用。
擴(kuò)展資料
在C++中,為了允許操作符重載和函數(shù)重載,C++編譯器往往按照某種規(guī)則改寫每一個入口點的符號名,以便允許同一個名字(具有不同的參數(shù)類型或者是不同的作用域)有多個用法,而不會打破現(xiàn)有的基于C的鏈接器。
這項技術(shù)通常被稱為名稱改編(Name Mangling)或者名稱修飾(Name Decoration)。許多C++編譯器廠商選擇了自己的名稱修飾方案。
請問C語言函數(shù)的調(diào)用規(guī)則是什么,例如主函數(shù)main、 函數(shù)A 、函數(shù)B,這3者的順序能否打亂,
可以打亂,依個人習(xí)慣。
如果 A函數(shù)放最前,能否直接調(diào)用B函數(shù)?還是只能后面的函數(shù)調(diào)用前面的函數(shù),還是說只要在A函數(shù)中聲明B函數(shù)就能夠調(diào)用后面的B函數(shù)。?
A調(diào)B,或B調(diào)A都可以,如果B在A后,B可直接調(diào)用A,否則,先在B前聲明一下A再調(diào)用A。
main函數(shù)的有沒有固定的位置,例如要放最前面?或最后面?
沒有要求,一般單獨一個C文件放main函數(shù)。
我需要程序調(diào)用這一部分的 語法描述圖,因為規(guī)則不是固定,所以畫起來有點難度,有沒人能提供 程序調(diào)用的語法描述圖 就是類似 void ---- ident----(----)----{----語句…… 這樣的圖。加分加分!!
不明白,寫兩個簡單函數(shù)實驗一下就知道了,這樣印象會深刻點不容易忘。
函數(shù)的調(diào)用
8.4.1 函數(shù)調(diào)用的一般形式
前面已經(jīng)說過,在程序中是通過對函數(shù)的調(diào)用來執(zhí)行函數(shù)體的,其過程與其它語言的子程序調(diào)用相似。
C語言中,函數(shù)調(diào)用的一般形式為:
函數(shù)名(實際參數(shù)表)
對無參函數(shù)調(diào)用時則無實際參數(shù)表。實際參數(shù)表中的參數(shù)可以是常數(shù),變量或其它構(gòu)造類型數(shù)據(jù)及表達(dá)式。各實參之間用逗號分隔。
8.4.2 函數(shù)調(diào)用的方式
在C語言中,可以用以下幾種方式調(diào)用函數(shù):
1. 函數(shù)表達(dá)式:函數(shù)作為表達(dá)式中的一項出現(xiàn)在表達(dá)式中,以函數(shù)返回值參與表達(dá)式的運算。這種方式要求函數(shù)是有返回值的。例如:z=max(x,y)是一個賦值表達(dá)式,把max的返回值賦予變量z。
2. 函數(shù)語句:函數(shù)調(diào)用的一般形式加上分號即構(gòu)成函數(shù)語句。例如: printf ("%d",a);scanf ("%d",b);都是以函數(shù)語句的方式調(diào)用函數(shù)。
3. 函數(shù)實參:函數(shù)作為另一個函數(shù)調(diào)用的實際參數(shù)出現(xiàn)。這種情況是把該函數(shù)的返回值作為實參進(jìn)行傳送,因此要求該函數(shù)必須是有返回值的。例如: printf("%d",max(x,y)); 即是把max調(diào)用的返回值又作為printf函數(shù)的實參來使用的。在函數(shù)調(diào)用中還應(yīng)該注意的一個問題是求值順序的問題。所謂求值順序是指對實參表中各量是自左至右使用呢,還是自右至左使用。對此,各系統(tǒng)的規(guī)定不一定相同。介紹printf 函數(shù)時已提到過,這里從函數(shù)調(diào)用的角度再強調(diào)一下。
【例8.3】
main()
{
int i=8;
printf("%d\n%d\n%d\n%d\n",++i,--i,i++,i--);
}
如按照從右至左的順序求值。運行結(jié)果應(yīng)為:
8
7
7
8
如對printf語句中的++i,--i,i++,i--從左至右求值,結(jié)果應(yīng)為:
9
8
8
9
應(yīng)特別注意的是,無論是從左至右求值, 還是自右至左求值,其輸出順序都是不變的, 即輸出順序總是和實參表中實參的順序相同。由于Turbo C現(xiàn)定是自右至左求值,所以結(jié)果為8,7,7,8。上述問題如還不理解,上機(jī)一試就明白了。
8.4.3 被調(diào)用函數(shù)的聲明和函數(shù)原型
在主調(diào)函數(shù)中調(diào)用某函數(shù)之前應(yīng)對該被調(diào)函數(shù)進(jìn)行說明(聲明),這與使用變量之前要先進(jìn)行變量說明是一樣的。在主調(diào)函數(shù)中對被調(diào)函數(shù)作說明的目的是使編譯系統(tǒng)知道被調(diào)函數(shù)返回值的類型,以便在主調(diào)函數(shù)中按此種類型對返回值作相應(yīng)的處理。
其一般形式為:
類型說明符 被調(diào)函數(shù)名(類型 形參,類型 形參…);
或為:
類型說明符 被調(diào)函數(shù)名(類型,類型…);
括號內(nèi)給出了形參的類型和形參名,或只給出形參類型。這便于編譯系統(tǒng)進(jìn)行檢錯,以防止可能出現(xiàn)的錯誤。
例8.1 main函數(shù)中對max函數(shù)的說明為:
int max(int a,int b);
或?qū)憺?
int max(int,int);
C語言中又規(guī)定在以下幾種情況時可以省去主調(diào)函數(shù)中對被調(diào)函數(shù)的函數(shù)說明。
1) 如果被調(diào)函數(shù)的返回值是整型或字符型時,可以不對被調(diào)函數(shù)作說明,而直接調(diào)用。這時系統(tǒng)將自動對被調(diào)函數(shù)返回值按整型處理。例8.2的主函數(shù)中未對函數(shù)s作說明而直接調(diào)用即屬此種情形。
2) 當(dāng)被調(diào)函數(shù)的函數(shù)定義出現(xiàn)在主調(diào)函數(shù)之前時,在主調(diào)函數(shù)中也可以不對被調(diào)函數(shù)再作說明而直接調(diào)用。例如例8.1中,函數(shù)max的定義放在main 函數(shù)之前,因此可在main函數(shù)中省去對max函數(shù)的函數(shù)說明int max(int a,int b)。
3) 如在所有函數(shù)定義之前,在函數(shù)外預(yù)先說明了各個函數(shù)的類型,則在以后的各主調(diào)函數(shù)中,可不再對被調(diào)函數(shù)作說明。例如:
char str(int a);
float f(float b);
main()
{
……
}
char str(int a)
{
……
}
float f(float b)
{
……
}
其中第一,二行對str函數(shù)和f函數(shù)預(yù)先作了說明。因此在以后各函數(shù)中無須對str和f函數(shù)再作說明就可直接調(diào)用。
4) 對庫函數(shù)的調(diào)用不需要再作說明,但必須把該函數(shù)的頭文件用include命令包含在源文件前部。
8.5 函數(shù)的嵌套調(diào)用
C語言中不允許作嵌套的函數(shù)定義。因此各函數(shù)之間是平行的,不存在上一級函數(shù)和下一級函數(shù)的問題。但是C語言允許在一個函數(shù)的定義中出現(xiàn)對另一個函數(shù)的調(diào)用。這樣就出現(xiàn)了函數(shù)的嵌套調(diào)用。即在被調(diào)函數(shù)中又調(diào)用其它函數(shù)。這與其它語言的子程序嵌套的情形是類似的。其關(guān)系可表示如圖。
圖表示了兩層嵌套的情形。其執(zhí)行過程是:執(zhí)行main函數(shù)中調(diào)用a函數(shù)的語句時,即轉(zhuǎn)去執(zhí)行a函數(shù),在a函數(shù)中調(diào)用b 函數(shù)時,又轉(zhuǎn)去執(zhí)行b函數(shù),b函數(shù)執(zhí)行完畢返回a函數(shù)的斷點繼續(xù)執(zhí)行,a函數(shù)執(zhí)行完畢返回main函數(shù)的斷點繼續(xù)執(zhí)行。
【例8.4】計算s=22!+32!
本題可編寫兩個函數(shù),一個是用來計算平方值的函數(shù)f1,另一個是用來計算階乘值的函數(shù)f2。主函數(shù)先調(diào)f1計算出平方值,再在f1中以平方值為實參,調(diào)用 f2計算其階乘值,然后返回f1,再返回主函數(shù),在循環(huán)程序中計算累加和。
long f1(int p)
{
int k;
long r;
long f2(int);
k=p*p;
r=f2(k);
return r;
}
long f2(int q)
{
long c=1;
int i;
for(i=1;i=q;i++)
c=c*i;
return c;
}
main()
{
int i;
long s=0;
for (i=2;i=3;i++)
s=s+f1(i);
printf("\ns=%ld\n",s);
}
在程序中,函數(shù)f1和f2均為長整型,都在主函數(shù)之前定義,故不必再在主函數(shù)中對f1和f2加以說明。在主程序中,執(zhí)行循環(huán)程序依次把i值作為實參調(diào)用函數(shù)f1求i2值。在f1中又發(fā)生對函數(shù)f2的調(diào)用,這時是把i2的值作為實參去調(diào)f2,在f2 中完成求i2!的計算。f2執(zhí)行完畢把C值(即i2!)返回給f1,再由f1返回主函數(shù)實現(xiàn)累加。至此,由函數(shù)的嵌套調(diào)用實現(xiàn)了題目的要求。由于數(shù)值很大,所以函數(shù)和一些變量的類型都說明為長整型,否則會造成計算錯誤。
嗯,我認(rèn)為也不能調(diào)用,
在func這個函數(shù)里,one被優(yōu)先識別為一個整形的變量,而不是一個函數(shù),
#include stdio.h
void one(int a,int b);
int func(int one,int c);
int main()
{
func(1,2);
return 0;
}
void one(int a,int b)
{
printf("%d %d",a,b);
}
int func(int one,int c)
{
printf("%d %d",one,c);
one(3,4);
}
在這段代碼里可證實我的說法,該代碼不能運行,錯誤信息為:"在func函數(shù)中one不能作為一個函數(shù)"