主函數(shù)不能調(diào)用自己。
成都創(chuàng)新互聯(lián)服務(wù)項目包括平遙網(wǎng)站建設(shè)、平遙網(wǎng)站制作、平遙網(wǎng)頁制作以及平遙網(wǎng)絡(luò)營銷策劃等。多年來,我們專注于互聯(lián)網(wǎng)行業(yè),利用自身積累的技術(shù)優(yōu)勢、行業(yè)經(jīng)驗、深度合作伙伴關(guān)系等,向廣大中小型企業(yè)、政府機(jī)構(gòu)等提供互聯(lián)網(wǎng)行業(yè)的解決方案,平遙網(wǎng)站推廣取得了明顯的社會效益與經(jīng)濟(jì)效益。目前,我們服務(wù)的客戶以成都為中心已經(jīng)輻射到平遙省份的部分城市,未來相信會繼續(xù)擴(kuò)大服務(wù)區(qū)域并繼續(xù)獲得客戶的支持與信任!
主函數(shù)實際上是有參函數(shù),從操作系統(tǒng)傳入變量,結(jié)束時有數(shù)值返回操作系統(tǒng)。
int main(int argc, char *argv[]){
return 0;
}
其中:
int argc, char *argv[] 從操作系統(tǒng)傳入
return 0; 返回操作系統(tǒng)
如果你的數(shù)據(jù)不需要同操作系統(tǒng)發(fā)生關(guān)系,你可以寫成自定義函數(shù),主函數(shù)里就一個語句--調(diào)用這個自定義函數(shù)。
錯,函數(shù)可以調(diào)用自己,函數(shù)自己調(diào)用自己的這種調(diào)用方式稱為函數(shù)的遞歸調(diào)用,我給你舉個列子:
int calc(int num){
if(num==0){
return 0;
}else{
return num*calc(num-1);
}
}
這個函數(shù)就是利用遞歸求任意一個整數(shù)的階乘
一,函數(shù)調(diào)用的一般形式為:
函數(shù)名(實參列表);
實參可以是常數(shù)、變量、表達(dá)式等,多個實參用逗號,分隔。
在c語言中,函數(shù)調(diào)用的方式有多種,例如:
在函數(shù)調(diào)用中還應(yīng)該注意的一個問題是求值順序的問題。所謂求值順序是指對實參列表中各個參數(shù)是自左向右使用呢,還是自右向左使用。對此,各系統(tǒng)的規(guī)定不一定相同。
【示例】在vc6.0下運(yùn)行以下代碼。
運(yùn)行結(jié)果:
8
7
6
7
可見vc
6.0是按照從右至左的順序求值。如果按照從左至右求值,結(jié)果應(yīng)為:
9
10
9
8
函數(shù)的嵌套調(diào)用
函數(shù)不能嵌套定義,但可以嵌套調(diào)用,也就是在一個函數(shù)的定義中出現(xiàn)對另一個函數(shù)的調(diào)用。這樣就出現(xiàn)了函數(shù)的嵌套調(diào)用,即在被調(diào)函數(shù)中又調(diào)用其它函數(shù)。
【示例】計算sum
=
1!
+
2!
+
3!
+
...
+
(n-1)!
+
n!
分析:可以編寫兩個函數(shù),一個用來計算階乘,一個用來計算累加的和。
#include
//求階乘
long
factorial(int
n){
int
i;
long
result=1;
for(i=1;
i=n;
i++){
result
*=
n;
}
return
result;
}
//
求累加的和
long
sum(long
n){
int
i;
long
result
=
0;
for(i=1;
i=n;
i++){
//嵌套調(diào)用
result
+=
factorial(n);
}
return
result;
}
int
main(){
printf("1!+2!+...+9!+10!
=
%ld\n",
sum(10));
return
0;
}
二,有些自定義函數(shù)可能會被頻繁的調(diào)用,所以寫在一個c文件里是不太方便的。應(yīng)該把這些自定義的函數(shù)寫在一個c文件里,同時在一個頭文件.h文件里聲明。主函數(shù)可以通過引用該頭文件然后調(diào)用需要的自定義函數(shù)。
1,舉例:在頭文件(.h)里聲明自定義函數(shù)
2,在一個c語言文件里寫下自定義函數(shù)的實現(xiàn)
3,在主函數(shù)中調(diào)用自定義函數(shù)
4,最后編譯所有的涉及到的c文件,頭文件可以不管