C語言函數(shù)聲明以及函數(shù)原型超詳細(xì)講解示例
C語言代碼由上到下依次執(zhí)行,原則上函數(shù)定義要出現(xiàn)在函數(shù)調(diào)用之前,否則就會(huì)報(bào)錯(cuò)。但在實(shí)際開發(fā)中,經(jīng)常會(huì)在函數(shù)定義之前使用它們,這個(gè)時(shí)候就需要提前聲明。
所謂聲明(Declaration),就是告訴編譯器我要使用這個(gè)函數(shù),你現(xiàn)在沒有找到它的定義不要緊,請(qǐng)不要報(bào)錯(cuò),稍后我會(huì)把定義補(bǔ)上。
函數(shù)聲明的格式非常簡(jiǎn)單,相當(dāng)于去掉函數(shù)定義中的函數(shù)體,并在最后加上分號(hào);,如下所示:
dataType functionName( dataType1 param1, dataType2 param2 ... );
也可以不寫形參,只寫數(shù)據(jù)類型:
dataType functionName( dataType1, dataType2 ... );
函數(shù)聲明給出了函數(shù)名、返回值類型、參數(shù)列表(重點(diǎn)是參數(shù)類型)等與該函數(shù)有關(guān)的信息,稱為函數(shù)原型(Function Prototype)。函數(shù)原型的作用是告訴編譯器與該函數(shù)有關(guān)的信息,讓編譯器知道函數(shù)的存在,以及存在的形式,即使函數(shù)暫時(shí)沒有定義,編譯器也知道如何使用它。
有了函數(shù)聲明,函數(shù)定義就可以出現(xiàn)在任何地方了,甚至是其他文件、靜態(tài)鏈接庫、動(dòng)態(tài)鏈接庫等。
【實(shí)例1】定義一個(gè)函數(shù) sum(),計(jì)算從 m 加到 n 的和,并將 sum() 的定義放到 main() 后面。
#include<stdio.h> //函數(shù)聲明 intsum(int m,int n);//也可以寫作int sum(int, int); intmain(){ int begin =5, end =86; int result =sum(begin, end); printf("The sum from %d to %d is %d\n", begin, end, result); return0; } //函數(shù)定義 intsum(int m,int n){ int i, sum=0; for(i=m; i<=n; i++){ sum+=i; } return sum; }
我們?cè)?main() 函數(shù)中調(diào)用了 sum() 函數(shù),編譯器在它前面雖然沒有發(fā)現(xiàn)函數(shù)定義,但是發(fā)現(xiàn)了函數(shù)聲明,這樣編譯器就知道函數(shù)怎么使用了,至于函數(shù)體到底是什么,暫時(shí)可以不用操心,后續(xù)再把函數(shù)體補(bǔ)上就行。
【實(shí)例2】定義兩個(gè)函數(shù),計(jì)算1! + 2! + 3! + ... + (n-1)! + n!的和。
#include<stdio.h> // 函數(shù)聲明部分 longfactorial(int n);//也可以寫作 long factorial(int); longsum(long n);//也可以寫作 long sum(long); intmain(){ printf("1!+2!+...+9!+10! = %ld\n",sum(10)); return0; } //函數(shù)定義部分 //求階乘 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++){ result +=factorial(i); } return result; }
運(yùn)行結(jié)果:
1!+2!+...+9!+10! = 4037913
初學(xué)者編寫的代碼都比較簡(jiǎn)單,頂多幾百行,完全可以放在一個(gè)源文件中。對(duì)于單個(gè)源文件的程序,通常是將函數(shù)定義放到 main() 的后面,將函數(shù)聲明放到 main() 的前面,這樣就使得代碼結(jié)構(gòu)清晰明了,主次分明。
使用者往往只關(guān)心函數(shù)的功能和函數(shù)的調(diào)用形式,很少關(guān)心函數(shù)的實(shí)現(xiàn)細(xì)節(jié),將函數(shù)定義放在最后,就是盡量屏蔽不重要的信息,凸顯關(guān)鍵的信息。將函數(shù)聲明放到 main() 的前面,在定義函數(shù)時(shí)也不用關(guān)注它們的調(diào)用順序了,哪個(gè)函數(shù)先定義,哪個(gè)函數(shù)后定義,都無所謂了。
然而在實(shí)際開發(fā)中,往往都是幾千行、上萬行、百萬行的代碼,將這些代碼都放在一個(gè)源文件中簡(jiǎn)直是災(zāi)難,不但檢索麻煩,而且打開文件也很慢,所以必須將這些代碼分散到多個(gè)文件中。對(duì)于多個(gè)文件的程序,通常是將函數(shù)定義放到源文件(.c文件)中,將函數(shù)的聲明放到頭文件(.h文件)中,使用函數(shù)時(shí)引入對(duì)應(yīng)的頭文件就可以,編譯器會(huì)在鏈接階段找到函數(shù)體。
到此這篇關(guān)于C語言函數(shù)聲明以及函數(shù)原型超詳細(xì)講解示例的文章就介紹到這了,更多相關(guān)C語言函數(shù)聲明內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
關(guān)于統(tǒng)計(jì)數(shù)字問題的算法
本文介紹了統(tǒng)計(jì)數(shù)字問題的算法,計(jì)算出書的全部頁碼中分別用到多少次數(shù)字0,1,2,3,.....9,并有每一步的解題思路,需要的朋友可以參考下2015-08-08Qt為exe添加ico圖片的簡(jiǎn)單實(shí)現(xiàn)步驟
這篇文章主要給大家介紹了關(guān)于Qt為exe添加ico圖片的簡(jiǎn)單實(shí)現(xiàn)步驟,通過文中介紹的方法可以幫助大家實(shí)現(xiàn)這個(gè)自定義exe圖標(biāo)的效果,文中通過圖文介紹的非常詳細(xì),需要的朋友可以參考下2022-07-07C++用read()和write()讀寫二進(jìn)制文件的超詳細(xì)教程
二進(jìn)制的文件肉眼我們是讀不懂的,如果通過二進(jìn)制的讀寫操作就可以讀懂,下面這篇文章主要給大家介紹了關(guān)于C++用read()和write()讀寫二進(jìn)制文件的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-06-06基于C語言實(shí)現(xiàn)簡(jiǎn)單的五子棋游戲
這篇文章主要為大家詳細(xì)介紹了基于C語言實(shí)現(xiàn)簡(jiǎn)單的五子棋游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-05-05