頭函數在預處理里面純判,也就是在里面包含做正改了很多的函數原型以及定義清兆。
創新互聯于2013年開始,是專業互聯網技術服務公司,擁有項目成都網站制作、成都網站建設、外貿營銷網站建設網站策劃,項目實施與項目整合能力。我們以讓每一個夢想脫穎而出為使命,1280元吉隆做網站,已為上家服務,為吉隆各地企業和個人服務,聯系電話:18982081108
比如stdio.h中就包含printf,scanf等等函數。
不包含會報警告。
在一個函數定義中,函數體之前的所有部分稱為函數頭,它給出了該函數的返回類型、每個參數的次序和類型等函數原型信息,所以當沒有專門給出函數原型說明語句時,系統就從函數頭中獲取函數原型信息。
一個函數的原型語句就是其函數頭的一個拷貝,當然要在最后加上語句接上結束符分號。函數原型語句與函數頭也有細微的差別,在函數原型語句中,其參數表中的每個參數允許只保留參數類型,而省略參數名,并且若使用參數名也允許與函數頭中對應的參數名不同。
全文如下:
一)、定義格式
類型名 函數名 ([參數表]) 函數體
類型名為系統或用戶已定義的一種數據類型,它是函數執行過程中通過return語句要求返回的值的類型,又稱為該函數的類型。當一個函數不需要通過return語句返回一個值時,稱為無返回值函數或無類型函數,此時需要使用保留字void作為類型名。當類型名為int時,可以省略不寫,但為了清楚起見,還是寫明為好。
函數名是用戶為函數所起的名字,它是一個標識符,應符合胡逗C++標識符的一般命名規則,用戶通過使用這個函數名和實參表可以調用該函數。
參數表又稱形式參數表,它包含有任意多個(含0個,即沒有)參數說明項,當多于一個時其前后兩個參數說明項之間必須用逗號分開。每個參數說明項由一種已定義的數據類型和一個變量標識符組成,該變量標識符成為該函數的形式參數,簡稱形參,形參前面給出的數據類型稱為該形參的類型。一個函數定義中的參數表可以被省略,表明該函數為無參函數,若參數表用void取代,則也表明是無參函數,若參數表不為空,同時又不是保留字void,則稱為帶參函數。
函數體是一條復合語句,它以左花括號開始,到右花括號結束,中間為一條或若干條肢做賀C++語句。
在一個函數的參數表中,每個參數可以為任一種數據類型,包括普通類型、指針類型、數組類型、引用類型等,一個函數的返回值可以是除數組類型之外的任何類型,包括普通類型、指針類型和引用類型等。另外,當不需要返回值時,應把函數定義為void類型。
二)、定義格式舉例
(1) void f1() {...}
(2) void f2(int x) {...}
(3) int f3(int x,int* p) {...}
(4) char* f4(char a[]){...}
(5) int f5(int x,double d) {...}
(6) int f6(int b[10], int n) {...}
(7) void f7(float c[][N], int m, float max) {...}
(8) bool f8(ElemType* bt, ElemType item) {...}
在第一條函數定義中,函數名為f1,函數類型為void,參數表為空,此函數是一個無參無類型函數。若在f1后面的圓括號內寫入保留字void,也表示為無參函數。
在第二條函數定義中,僅帶有一個類型為int的形參變量x,該函數沒有返回值。
在第三條函數定義中,函數名為f3,函數類型為int,函數參數為x和p,其中x為int型普通參數,p為int*型指針參數。
在第四條函數定義中,函數名為f4,函數類型為char*,即字符指針類型,參數表中包含一個一維字符數組參數。注意:在定義任何類型的一維數組參數時,不需要給出維的尺寸,當然給出也是允許的,但沒有任何意義。
在第五條函數定義中,函數名為f5,返回類型為int,該函數帶有兩個形參,一個為 整型引用變量x,另一個為雙精度變量d。
在第六條函數定義中,函數名為f6,函數類型為歷派int,即整型引用,該函數帶有兩個形參,一個是整型數組b,另一個是整型變量n。在這里定義形參數組b所給出的維的尺寸10可以被省略。
在第七條函數定義中,函數名為f7,無函數類型,參數表中包含三個參數,一個為二維單精度型數組c,第二個為整型變量m,第三個為單精度引用變量max。注意:當定義一個二維數組參數時,第二維的尺寸必須給出,并且必須是一個常量表達式,第一維尺寸可給出也可不給出,其作用相同。
在第八條函數定義中,函數名為f8,返回類型為bool,即邏輯類型,該函數帶有兩個參數,一個為形參bt,它為ElemType的指針引用類型,另一個為形參item,它是ElemType的引用類型,其中ElemType為一種用戶定義的類型或是通過typedef語句定義的一個類型的別名。
三)、有關函數定義的幾點說明
1. 函數原型語句
在一個函數定義中,函數體之前的所有部分稱為函數頭,它給出了該函數的返回類型、每個參數的次序和類型等函數原型信息,所以當沒有專門給出函數原型說明語句時,系統就從函數頭中獲取函數原型信息。
一個函數必須先定義或聲明而后才能被調用,否則編譯程序無法判斷該調用的正確性。一個函數的聲明是通過使用一條函數原型語句實現的,當然使用多條相同的原型語句聲明同一個函數雖然多余但也是允許的,編譯時不會出現錯誤。
在一個完整的程序中,函數的定義和函數的調用可以在同一個程序文件中,也可以處在不同的程序文件中,但必須確保函數原型語句與函數調用表達式出現在同一個文件中,并且函數原型語句出現在前,函數的調用出現在后。
通常把一個程序中用戶定義的所有函數的原型語句組織在一起,構成一個頭文件,讓該程序中所含的每個程序文件的開始(即所有函數定義之前)包含這個頭文件(通過#include命令實現),這樣不管每個函數的定義在哪里出現,都能夠確保函數先聲明后使用(即調用)這一原則的實現。
一個函數的原型語句就是其函數頭的一個拷貝,當然要在最后加上語句接上結束符分號。函數原型語句與函數頭也有細微的差別,在函數原型語句中,其參數表中的每個參數允許只保留參數類型,而省略參數名,并且若使用參數名也允許與函數頭中對應的參數名不同。
2. 常量形參
在定義一個函數時,若只允許函數體訪問一個形參的值,不允許修改它的值,則應把該形參說明為常量,這只要在形參說明的前面加上const保留字進行修飾即可。如:
void f9(const int x, const char y);
void f10(const char* p, char key);
在函數f9的函數體中只允許使用x和y的值,不允許修改它們的值。在函數f10的函數體中只允許使用p所指向的字符對象或字符數組對象的值,不允許修改它們的值,但在函數體中既允許使用也允許修改形參key的值。
3. 缺省參數
在一個函數定義中,可根據需要對參數表末尾的一個或連續若干個參數給出缺省值,當調用這個函數時,若實參表中沒有給出對應的實參,則形參將采用這個缺省值。如:
void f11(int x, int y=0) {...}
int f12(int a[], char op='+', int k=10) {...}
函數f11的定義帶有兩個參數,分別為整型變量x和y,并且y帶有缺省值0,若調用該函數的表達式為f11(a,b),將把a的值賦給x,把b的值賦給y,接著執行函數體;若調用該函數的表達式為f11(a+b),則也是正確的調用格式,它將把a+b的值賦給x,因y沒有對應的實參,將采用缺省值0,參數傳送后接著執行函數體。
函數f12的定義帶有三個參數,其中后兩個帶有缺省值,所以調用它的函數格式有三種,一種只帶一個實參,用于向形參a傳送數據,后兩個形參采用缺省值,第二種帶有兩個實參,用于分別向形參a和op傳送數據,第三個形參采用缺省值,第三種帶有三個實參,分別用于傳送給三個形參。
若一個函數帶有專門的函數原型語句,則形參的缺省值只能在該函數原型語句中給出,不允許在函數頭中給出。如對于上述的f11和f12函數,其對應的函數原型語句分別為:
void f11(int x, int y=0);
int f12(int a[], char op='+', int k=10);
函數定義應分別改寫為:
void f11(int x, int y) {...}
int f12(int a[], char op, int k) {...}
4. 數組參數
在函數定義中的每個數組參數實際上是指向元素類型的指針參數。對于一維數組參數說明:
數據類型 數組名[]
它與下面的指針參數說明完全等價:
數據類型 *指針變量名
其中指針變量名就是數組參數說明中的數組名。如對于f12函數定義中的數組參數說明int a[],等價于指針參數說明int* a。也就是說,數組參數說明中的數組名a是一個類型為int*的形參。注意:在變量定義語句中定義的數組,其數組名代表的是一個數組,它的值是指向第一個元素的指針常量,這與數組形參的含義有區別。
對于二維數組參數說明:
數據類型 參數名[][第二維尺寸]
它與下面的指針參數說明完全等價:
數據類型 (*參數名)[第二維尺寸]
如對于f7函數定義中的二維數組參數說明float c[][N],等價于指針參數說明float(*c)[N]。
5. 函數類型
當調用一個函數時就執行一遍循環體,對于類型為非void的函數,函數體中至少必須帶有一條return語句,并且每條return語句必須帶有一個表達式,當執行到任一條return語句時,將計算出它的表達式的值,結束整個函數的調用過程,把這個值作為所求的函數值帶回到調用位置,參與相應的運算;對于類型為void的函數,它不需要返回任何函數值,所以在函數體中既可以使用return語句,也可以不使用,對于使用的每條return語句不允許也不需要帶有表達式,當執行到任一條return語句時,或執行到函數體最后結束位置時,將結束函數的調用過程,返回到調用位置向下繼續執行。
6. 內聯函數
當在一個函數的定義或聲明前加上關鍵字inline則就把該函數聲明為內聯函數。計算機在執行一般函數的調用時,無論該函數多么簡單或復雜,都要經過參數傳遞、執行函數體和返回等操作。若把一個函數聲明為內聯函數后,在程序編譯階段系統就有可能把所有調用該函數的地方都直接替換為該函數的執行代碼,由此省去函數調用時的參數傳遞和返回操作,從而加快整個程序的執行速度。通常可把一些相對簡單的函數聲明為內聯函數,對于較復雜的函數則不應聲明為內聯函數。從用戶的角度看,調用內聯函數和一般函數沒有任何區別。下面就是一個內聯函數定義的例子,它返回形參值的立方。
inline int cube(int n)
{
return n*n*n;
}
C語言
函數:C語言里執行的就是函數,函數里有很多族困執行喊宴語句,這個函數并不是數學里面的函數,可以理解成一個容器,這個容器里有很多可以執行的語句。C語言從main函數開始執行。
頭文件:就是寫在開頭用#include寫的語句,如
#includestdio.h
#includemath.h
#includestring.h
里面的英文就是“庫函數”,函數兆滲念里的執行語句都是需要從庫函數里調用,這個調用行為不用咱們管。比如:printf函數、scanf函數就需要頭文件包含stdio.h這個庫函數。
pow(求冪函數)就需要頭文件包含math.h。
返回值:就是一個函數返回的值,任何一個沒有定義成void型的函數都有返回值,定義void型的函數沒有返回值。如:
int hanshu()
{
return 1;
}
這個hanshu函數的返回值就是1。
如果再有語句,如下:
int a;
a=hanshu();
那么a的值就是1
本人純原創,拒絕復制。如有疑問請您追問,滿意的話記得采納哦~~~
頭文件就是你寫的函數包含在這個文件中,必須包含了這個頭文件函數才能調用,執行。像基本的輸入輸出函數printf和scanf就是包含在stdio.h中的。主函數是程序的入口函運毀旁數旁橡余仿,一個C程序開始運行的第一個函數就是主函數。
標題名稱:c語言函數頭概念 c語言函數頭
文章URL:http://vcdvsql.cn/article18/ddpiigp.html
成都網站建設公司_創新互聯,為您提供網站內鏈、面包屑導航、網站導航、網站制作、企業建站、網站營銷
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯