前面已經介紹過,函數的參數分為形參和實參兩種。在本節中,進一步介紹形參、實參的特點和兩者的關系。形參出現在函數定義中,在整個函數體內都可以使用,離開該函數則不能使用。
實參出現在主調函數中,進入被調函數後,實參變量也不能使用。形參和實參的功能是作數據傳送。發生函數調用時,主調函數把實參的值傳送給被調函數的形參從而實現主調函數向被調函數的數據傳送。
函數的形參和實參具有以下特點:
函數調用中發生的數據傳送是單向的。即只能把實參的值傳送給形參,而不能把形參的值反向地傳送給實參。 因此在函數調用過程中,形參的值發生改變,而實參中的值不會變化。
【例8-2】計算 1+2+3+...+(n-1)+n 的值。
#include <stdio.h> int s(int n){ int i; for(i=n-1;i>=1;i--) n=n+i; printf("The inner n = %d\n",n); return n; } int main(void){ int n, total; printf("Input a number: "); scanf("%d",&n); total = s(n); printf("The outer n = %d \n",n); printf("1+2+3+...+(n-1)+n = %d\n", total); return 0; }
運行結果:
Input a number: 100↙
The inner n = 5050
The outer n = 100
1+2+3+. ..+(n-l)+n = 5050
本程序中定義了一個函數s,該函數的功能是求 1+2+3+...+(n-1)+n 的值。在主函數中輸入n值,並作為實參,在調用時傳送給s 函數的形參量n( 注意,本例的形參變量和實參變量的標識符都為n,但這是兩個不同的量,各自的作用域不同)。在主函數中用printf 語句輸出一次n值,這個n值是實參n的值。在函數s中也用printf 語句輸出了一次n值,這個n值是形參最後取得的n值。從運行情況看,輸入n值為100。即實參n的值為100。把此值傳給函數s時,形參n的初值也為100,在執行函數過程中,形參n的值變為5050。返回主函數之後,輸出實參n的值仍為100。可見實參的值不隨形參的變化而變化。
經讀者 @木木有信仰 @好帥的小黑 反饋,筆者更改了錯誤代碼,更改時間為 2014-07-06 17:07:45。上面的代碼和分析是最新的,錯誤的代碼就不提供了。
函數的值(或稱函數返回值)是指函數被調用之後,執行函數體中的程序段所取得的並返回給主調函數的值。如調用正弦函數取得正弦值,調用【例8-1】的max函數取得的最大數等。對函數的值有以下一些說明:
1) 函數的值只能通過return語句返回主調函數。return語句的一般形式為:
return 表達式;
或者為:
return (表達式);
該語句的功能是計算表達式的值,並返回給主調函數。在函數中允許有多個return語句,但每次調用只能有一個return 語句被執行,因此只能返回一個函數值。
2) 函數值的類型和函數定義中函數的類型應保持一致。如果兩者不一致,則以函數類型為准,自動進行類型轉換。
3) 如函數值為整型,在函數定義時可以省去類型說明。
4) 不返回函數值的函數,可以明確定義為“空類型”,類型說明符為“void”。如【例8-2】中函數s並不向主函數返函數值,因此可定義為:
void s(int n){ /* …… */ }
一旦函數被定義為空類型後,就不能在主調函數中使用被調函數的函數值了。例如,在定義s為空類型後,在主函數中寫下述語句
sum=s(n);
就是錯誤的。
為了使程序有良好的可讀性並減少出錯, 凡不要求返回值的函數都應定義為空類型。