C語言函數(shù)調(diào)用基礎(chǔ)應(yīng)用詳解
所謂函數(shù)調(diào)用(Function Call),就是使用已經(jīng)定義好的函數(shù)。函數(shù)調(diào)用的一般形式為:
functionName(param1, param2, param3 ...);
functionName 是函數(shù)名稱,param1, param2, param3 ...是實(shí)參列表。實(shí)參可以是常數(shù)、變量、表達(dá)式等,多個(gè)實(shí)參用逗號(hào),分隔。
在C語言中,函數(shù)調(diào)用的方式有多種,例如:
//函數(shù)作為表達(dá)式中的一項(xiàng)出現(xiàn)在表達(dá)式中 z =max(x, y); m = n +max(x, y); //函數(shù)作為一個(gè)單獨(dú)的語句 printf("%d", a); scanf("%d",&b); //函數(shù)作為調(diào)用另一個(gè)函數(shù)時(shí)的實(shí)參 printf("%d",max(x, y)); total(max(x, y),min(m, n));
函數(shù)的嵌套調(diào)用
函數(shù)不能嵌套定義,但可以嵌套調(diào)用,也就是在一個(gè)函數(shù)的定義或調(diào)用過程中允許出現(xiàn)對另外一個(gè)函數(shù)的調(diào)用。
【示例】計(jì)算sum = 1! + 2! + 3! + ... + (n-1)! + n!
分析:可以編寫兩個(gè)函數(shù),一個(gè)用來計(jì)算階乘,一個(gè)用來計(jì)算累加的和。
#include<stdio.h> //求階乘 longfactorial(int n){ int i; long result=1; for(i=1; i<=n; i++){ result *= i; } return result; } // 求累加的和 longsum(long n){ int i; long result =0; for(i=1; i<=n; i++){ //在定義過程中出現(xiàn)嵌套調(diào)用 result +=factorial(i); } return result; } intmain(){ printf("1!+2!+...+9!+10! = %ld\n",sum(10));//在調(diào)用過程中出現(xiàn)嵌套調(diào)用 return0; }
運(yùn)行結(jié)果:
1!+2!+...+9!+10! = 4037913
sum() 的定義中出現(xiàn)了對 factorial() 的調(diào)用,printf() 的調(diào)用過程中出現(xiàn)了對 sum() 的調(diào)用,而 printf() 又被 main() 調(diào)用,它們整體調(diào)用關(guān)系為:
main() --> printf() --> sum() --> factorial()
如果一個(gè)函數(shù) A() 在定義或調(diào)用過程中出現(xiàn)了對另外一個(gè)函數(shù) B() 的調(diào)用,那么我們就稱 A() 為主調(diào)函數(shù)或主函數(shù),稱 B() 為被調(diào)函數(shù)。
當(dāng)主調(diào)函數(shù)遇到被調(diào)函數(shù)時(shí),主調(diào)函數(shù)會(huì)暫停,CPU 轉(zhuǎn)而執(zhí)行被調(diào)函數(shù)的代碼;被調(diào)函數(shù)執(zhí)行完畢后再返回主調(diào)函數(shù),主調(diào)函數(shù)根據(jù)剛才的狀態(tài)繼續(xù)往下執(zhí)行。
一個(gè)C語言程序的執(zhí)行過程可以認(rèn)為是多個(gè)函數(shù)之間的相互調(diào)用過程,它們形成了一個(gè)或簡單或復(fù)雜的調(diào)用鏈條。這個(gè)鏈條的起點(diǎn)是 main(),終點(diǎn)也是 main()。當(dāng) main() 調(diào)用完了所有的函數(shù),它會(huì)返回一個(gè)值(例如return 0;)來結(jié)束自己的生命,從而結(jié)束整個(gè)程序。
函數(shù)是一個(gè)可以重復(fù)使用的代碼塊,CPU 會(huì)一條一條地挨著執(zhí)行其中的代碼,當(dāng)遇到函數(shù)調(diào)用時(shí),CPU 首先要記錄下當(dāng)前代碼塊中下一條代碼的地址(假設(shè)地址為 0X1000),然后跳轉(zhuǎn)到另外一個(gè)代碼塊,執(zhí)行完畢后再回來繼續(xù)執(zhí)行 0X1000 處的代碼。整個(gè)過程相當(dāng)于 CPU 開了一個(gè)小差,暫時(shí)放下手中的工作去做點(diǎn)別的事情,做完了再繼續(xù)剛才的工作。
從上面的分析可以推斷出,在所有函數(shù)之外進(jìn)行加減乘除運(yùn)算、使用 if...else 語句、調(diào)用一個(gè)函數(shù)等都是沒有意義的,這些代碼位于整個(gè)函數(shù)調(diào)用鏈條之外,永遠(yuǎn)都不會(huì)被執(zhí)行到。C語言也禁止出現(xiàn)這種情況,會(huì)報(bào)語法錯(cuò)誤,請看下面的代碼:
#include<stdio.h> int a =10, b =20, c; //錯(cuò)誤:不能出現(xiàn)加減乘除運(yùn)算 c = a + b; //錯(cuò)誤:不能出現(xiàn)對其他函數(shù)的調(diào)用 printf("csdn.net"); intmain(){ return0; }
到此這篇關(guān)于C語言函數(shù)調(diào)用基礎(chǔ)應(yīng)用詳解的文章就介紹到這了,更多相關(guān)C語言函數(shù)調(diào)用內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C語言實(shí)現(xiàn)紅黑樹詳細(xì)步驟+代碼
大家好,本篇文章主要講的是C語言實(shí)現(xiàn)紅黑樹詳細(xì)步驟+代碼,感興趣的同學(xué)趕快來看一看吧,對你有幫助的話記得收藏一下2022-01-01C++ STL入門教程(3) deque雙向隊(duì)列使用方法
這篇文章主要為大家詳細(xì)介紹了C++ STL入門教程第三篇,deque雙向隊(duì)列的使用方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-08-08C++中Operator類型強(qiáng)制轉(zhuǎn)換成員函數(shù)解析
轉(zhuǎn)換函數(shù)定義了由<類型說明符1>到<類型說明符2>之間的映射關(guān)系??梢姡D(zhuǎn)換函數(shù)是用來將一種類型的數(shù)據(jù)轉(zhuǎn)換成為另一種類型2013-09-09