- 相關推薦
C語言的函數分類
可以說C程序的全部工作都是由各式各樣的函數完成的, 所以也把C語言稱為函數式語言。 由于采用了函數模塊式的結構, C語言易于實現結構化程序設計。使程序的層次結構清晰,便于程序的編寫、閱讀、調試。下面就和小編一起看看C語言的函數分類吧。
C語言的函數分類
在C語言中可從不同的角度對函數分類。
1. 從函數定義的角度看,函數可分為庫函數和用戶定義函數兩種。
(1)庫函數
由C系統提供,用戶無須定義, 也不必在程序中作類型說明,只需在程序前包含有該函數原型的頭文件即可在程序中直接調用。在前面各章的例題中反復用到printf 、 scanf 、 getchar 、putchar、gets、puts、strcat等函數均屬此類。
(2)用戶定義函數
由用戶按需要寫的函數。對于用戶自定義函數, 不僅要在程序中定義函數本身, 而且在主調函數模塊中還必須對該被調函數進行類型說明,然后才能使用。
2. C語言的函數兼有其它語言中的函數和過程兩種功能,從這個角度看,又可把函數分為有返回值函數和無返回值函數兩種。
(1)有返回值函數
此類函數被調用執行完后將向調用者返回一個執行結果, 稱為函數返回值。如數學函數即屬于此類函數。 由用戶定義的這種要返回函數值的函數,必須在函數定義和函數說明中明確返回值的類型。
(2)無返回值函數
此類函數用于完成某項特定的處理任務, 執行完成后不向調用者返回函數值。這類函數類似于其它語言的過程。 由于函數無須返回值,用戶在定義此類函數時可指定它的返回為“空類型”, 空類型的說明符為“void”。
3. 從主調函數和被調函數之間數據傳送的角度看又可分為無參函數和有參函數兩種。
(1)無參函數
函數定義、函數說明及函數調用中均不帶參數。 主調函數和被調函數之間不進行參數傳送。 此類函數通常用來完成一組指定的功能,可以返回或不返回函數值。
(2)有參函數
也稱為帶參函數。在函數定義及函數說明時都有參數, 稱為形式參數(簡稱為形參)。在函數調用時也必須給出參數, 稱為實際參數(簡稱為實參)。 進行函數調用時,主調函數將把實參的值傳送給形參,供被調函數使用。
4. C語言提供了極為豐富的庫函數, 這些庫函數又可從功能角度作以下分類。
(1)字符類型分類函數
用于對字符按ASCII碼分類:字母,數字,控制字符,分隔符,大小寫字母等。
(2)轉換函數
用于字符或字符串的轉換;在字符量和各類數字量 (整型, 實型等)之間進行轉換;在大、小寫之間進行轉換。
(3)目錄路徑函數
用于文件目錄和路徑操作。
(4)診斷函數
用于內部錯誤檢測。
(5)圖形函數
用于屏幕管理和各種圖形功能。
(6)輸入輸出函數
用于完成輸入輸出功能。
(7)接口函數
用于與DOS,BIOS和硬件的接口。
(8)字符串函數
用于字符串操作和處理。
(9)內存管理函數
用于內存管理。
(10)數學函數
用于數學函數計算。
(11)日期和時間函數
用于日期,時間轉換操作。
(12)進程控制函數
用于進程管理和控制。
(13)其它函數
用于其它各種功能。
以上各類函數不僅數量多,而且有的還需要硬件知識才會使用,因此要想全部掌握則需要一個較長的學習過程。 應首先掌握一些最基本、 最常用的函數,再逐步深入。
拓展:C語言基本算法
1.交換(兩量交換借助第三者)
例1、任意讀入兩個整數,將二者的值交換后輸出。
main()
{int a,b,t;
scanf("%d%d",&a,&b);
printf("%d,%d ",a,b);
t=a; a=b; b=t;
printf("%d,%d ",a,b);}
【解析】程序中加粗部分為算法的核心,如同交換兩個杯子里的飲料,必須借助第三個空杯子。
假設輸入的值分別為3、7,則第一行輸出為3,7;第二行輸出為7,3。
其中t為中間變量,起到“空杯子”的作用。
注意:三句賦值語句賦值號左右的各量之間的關系!
【應用】
例2、任意讀入三個整數,然后按從小到大的順序輸出。
main()
{int a,b,c,t;
scanf("%d%d%d",&a,&b,&c);
if(a>b){ t=a; a=b; b=t; }
if(a>c){ t=a; a=c; c=t; }
if(b>c) { t=b; b=c; c=t; }
printf("%d,%d,%d ",a,b,c);}
2.累加
累加算法的要領是形如“s=s+A”的累加式,此式必須出現在循環中才能被反復執行,從而實現累加功能。“A”通常是有規律變化的表達式,s在進入循環前必須獲得合適的初值,通常為0。
例1、求1+2+3+……+100的和。
main()
{int i,s;
s=0; i=1;
while(i<=100)
{s=s+i;
i=i+1;
}
printf("1+2+3+...+100=%d ",s);}
【解析】程序中加粗部分為累加式的典型形式,賦值號左右都出現的變量稱為累加器,其中“i = i + 1”為特殊的累加式,每次累加的值為1,這樣的累加器又稱為計數器。
3.累乘
累乘算法的要領是形如“s=s*A”的累乘式,此式必須出現在循環中才能被反復執行,從而實現累乘功能。“A”通常是有規律變化的表達式,s在進入循環前必須獲得合適的初值,通常為1。
例1、求10!
[分析]10!=1×2×3×……×10
main()
{int i; long c;
c=1; i=1;
while(i<=10)
{c=c*i;
i=i+1;
}
printf("1*2*3*...*10=%ld ",c);}
【C語言的函數分類】相關文章:
淺談C語言函數03-28
C語言函數 atoi()03-23
C語言函數的含義06-15
什么是C語言函數01-22
C語言函數的定義07-13
C語言的數組與函數02-28
C語言函數的聲明以及函數原型04-20
C語言的指針型函數02-20
C語言常用的輸入函數12-20