C語言中一個函數(shù)(function)是一個可以從程序其它地方調(diào)用執(zhí)行的語句塊。
成都創(chuàng)新互聯(lián)2013年至今,是專業(yè)互聯(lián)網(wǎng)技術(shù)服務(wù)公司,擁有項目網(wǎng)站設(shè)計、成都網(wǎng)站制作網(wǎng)站策劃,項目實施與項目整合能力。我們以讓每一個夢想脫穎而出為使命,1280元龍鳳做網(wǎng)站,已為上家服務(wù),為龍鳳各地企業(yè)和個人服務(wù),聯(lián)系電話:028-86922220
1、通過使用函數(shù)(functions)我們可以把我們的程序以更模塊化的形式組織起來,從而利用C語言所支持的結(jié)構(gòu)化程序設(shè)計。
2、從數(shù)學角度,函數(shù)即集合A和集合B之間的映射關(guān)系。實際上計算機中的函數(shù)概念也是源于此,因此,一般函數(shù),都有形參和返回值。
3、從計算機組成原理的角度來看,函數(shù)即是一個小型的計算機系統(tǒng),依據(jù)馮諾伊曼的“存儲程序原理”,每一個計算機系統(tǒng)包含:輸入系統(tǒng)、輸出系統(tǒng)、運算器以及控制器,實際上對于C語言中的函數(shù)來說,它是“存儲程序原理”的軟實現(xiàn),其中形參、實參這是輸入系統(tǒng),返回值是輸出系統(tǒng),函數(shù)體中的運算符,比如+、-、*、/四則運算即為運算器,而邏輯運算符以及if、while等控制語句便是一個控制器。
假設(shè)主函數(shù)main()。其他函數(shù)void fun(int a,int *b)。
關(guān)于函數(shù)定義和聲明:
在代碼中fun函數(shù),有完整函數(shù)體的代碼就是函數(shù)定義部分,比如void fun(int a,int *b){。。。};。
如果沒有具體實現(xiàn)的函數(shù)體代碼(也就是大括號內(nèi)容),那么就是函數(shù)聲明。比如void fun(int ,int *);
關(guān)于函數(shù)聲明和調(diào)用:
如果fun函數(shù)定義在main代碼上面。比如:
void fun(int a,int *b){。。。};
int main(){
int a=0,int b=0;
......
fun(a,b);//這里fun定義代碼在main上面,所以可以不需要聲明。反之需要先寫聲明語句
return 0;
}
關(guān)于函數(shù)局部變量及全局變量:
簡單區(qū)分:
定義在函數(shù)之外的就是全局變量,這個變量所有函數(shù)都可以直接使用,并且共用同一個地址。任意函數(shù)修改了變量值,其他函數(shù)調(diào)用也會變。
定義在函數(shù)之內(nèi)的就是局部變量,局部變量只屬于該函數(shù),其他函數(shù)即使定義了同樣名字的變量,這兩個變量也不同地址,互不相干。
比如:
int a;//這就是全局變量,作用域下所有函數(shù)共用
int main()
{
int b;//這就是局部變量,只在本函數(shù)有效,如果想在調(diào)用fun函數(shù)時讓fun也使用該變量,需要把這個變量的地址作為參數(shù)傳遞過去。
printf("%d",b);
return 0;
}
注意:c語言中允許局部變量和全局變量同名,但是同名的局部變量會屏蔽全局變量,實際代碼避免同名。
關(guān)于函數(shù)傳值和傳址:
如函數(shù)void fun(int a,int *b){..........};這里形參a 和*b,分別表示一個值和一個地址
所以在調(diào)用該函數(shù)時,比如:
int main()
{
int c,d;
fun(c,d);//這里調(diào)用就對應(yīng)上面形參類型,第一個參數(shù)傳遞了c的值(傳值),第二個參數(shù)傳遞了d的地址(傳址),這里c和d,叫做實參。當fun函數(shù)運行時改變了a和b指向地址的值,對應(yīng)main函數(shù)中c的值不變,d的值改變。
return 0;
}
順帶一說:局部變量,在函數(shù)運行結(jié)束后會自動釋放,所以想把局部變量地址作為返回值,需要用malloc函數(shù)申請。(這里看不懂可以暫時忽視)
C語言的函數(shù)定義格式是:
函數(shù)類型 函數(shù)名稱 ( 參數(shù)列表 )
{
//函數(shù)體
}
函數(shù)聲明,不是說明的格式是“函數(shù)定義格式”的第一行,然后加 “;”,即:
函數(shù)類型 函數(shù)名稱 ( 參數(shù)列表 );
特別地,在函數(shù)聲明中的參數(shù)列表中,不需要給出具體的變量名稱,但必須給出每個變量的類型。
函數(shù)原型能告訴編譯程序一個函數(shù)將接受什么樣的參數(shù),將返回什么樣的返回值,這樣編譯程序就能檢查對函數(shù)的調(diào)用是否正確,是否存在錯誤的類型轉(zhuǎn)換。例如,現(xiàn)有以下函數(shù)原型;
int
some_func(int,char·,long);
編譯程序就會檢查所有對該函數(shù)的引用(包括該函數(shù)的定義)是否使用了三個參數(shù)并且返回一個int類型的值。如果編譯程序發(fā)現(xiàn)函數(shù)的調(diào)用或定義與函數(shù)原型不匹配,編譯程序就會報告出錯或警告消息。例如,對上述函數(shù)原型來說,當編譯程序檢查以下語句時,就會報告出錯或警告消息:
x
=
some_func(l);
/*
not
enough
arguments
passed
*/
x
=
somc_funcc*hellol",
1,
"dude:");
/*
wrong
type
of
arguments
used
*/
x
=
aome_funcd,
sir,
2879,
"t");
/*
too
many
arguments
passed
*/
下例中的函數(shù)調(diào)用同樣是不正確的,因為函數(shù)some_func()的返回值不是一個long*類型的值。
lvalue=some_func(1,str,2879);
/*some_rune()returns
anint,not
a
long*
*/
同樣,編譯程序還能檢查函數(shù)的定義(或函數(shù)體)是否與函數(shù)原型匹配。例如,當編譯程序檢查以下函數(shù)定義時,就會報告出錯或警告消息:
int
some_func(char
*string,longlvalue,int
ivalue)
/*
wrong
order
of
{
parameters
*/
......
}
總之,在源文件中說明函數(shù)原型提供了一種檢查函數(shù)是否被正確引用的機制。目前許多流行的編譯程序都會檢查被引用的函數(shù)的原型是否已在源文件中說明過,如果沒有,就會發(fā)出警告消息。