C++形參與實參的區(qū)別實例解析
本文以實例闡述了C++中形參與實參的區(qū)別,有助于讀者加深對于C++形參與實參的認識。
形參出現(xiàn)在函數(shù)定義中,在整個函數(shù)體內都可以使用, 離開該函數(shù)則不能使用。實參出現(xiàn)在主調函數(shù)中,進入被調函數(shù)后,實參變量也不能使用。 形參和實參的功能是作數(shù)據(jù)傳送。發(fā)生函數(shù)調用時, 主調函數(shù)把實參的值傳送給被調函數(shù)的形參從而實現(xiàn)主調函數(shù)向被調函數(shù)的數(shù)據(jù)傳送。
1.形參變量只有在被調用時才分配內存單元,在調用結束時, 即刻釋放所分配的內存單元。因此,形參只有在函數(shù)內部有效。 函數(shù)調用結束返回主調函數(shù)后則不能再使用該形參變量。
2.實參可以是常量、變量、表達式、函數(shù)等, 無論實參是何種類型的量,在進行函數(shù)調用時,它們都必須具有確定的值, 以便把這些值傳送給形參。 因此應預先用賦值,輸入等辦法使實參獲得確定值。
3.實參和形參在數(shù)量上,類型上,順序上應嚴格一致, 否則會發(fā)生“類型不匹配”的錯誤。
4.函數(shù)調用中發(fā)生的數(shù)據(jù)傳送是單向的。 即只能把實參的值傳送給形參,而不能把形參的值反向地傳送給實參。 因此在函數(shù)調用過程中,形參的值發(fā)生改變,而實參中的值不會變化。
參考如下示例:
void Exchg1(int x, int y)
{
int tmp;
tmp=x;
x=y;
y=tmp;
printf("Exchg1:x=%d,y=%d\n",x,y);
}
void Exchg2(int &x, int &y)
{
int tmp;
tmp=x;
x=y;
y=tmp;
printf("Exchg2:x=%d,y=%d\n",x,y);
}
void Exchg3(int *x, int *y)
{
int tmp;
tmp=*x;
*x=*y;
*y=tmp;
printf("Exchg3:x=%d,y=%d\n",*x,*y);
}
void main()
{
int a=4,b=6;
Exchg1 (a,b) ;
printf("a=%d,b=%d\n",a,b);
Exchg2 (a,b);
printf("a=%d,b=%d\n",a,b);
Exchg3(&a,&b) ;
printf("a=%d,b=%d\n",a,b);
}
這里Exchg1函數(shù)被調用的時候,并沒有成功交換a跟b的數(shù)據(jù)。為何呢。
int a=4,b=6;
Exchg1 (a,b) ; //這里本質上發(fā)生的是:Exchg1 (intx=a,int y=b) ; x跟y是函數(shù)定義里面的形參,也就是說這里只是把實參a跟b的值賦予了x,y這2個形參變量。接下來,函數(shù)里發(fā)生的值互換只換掉了x跟y的值,而實參a跟b沒有影響。
再看Exchg2 (a,b); //再看本質Exchg2 (int &x=a,int &y=b); 這里x跟y都是a,b的引用,操作x跟y交換就等于a跟b交換,自然,調用Exchg2 可以成功交換a跟b
Exchg3(&a,&b) ; //Exchg3(int *x=&a,int *y=&b); x跟y2個形參是a跟b的指針,也就是實參數(shù)據(jù)存放的地址。然后函數(shù)里交換了x跟y指向的數(shù)據(jù),也就是實參a跟b,所以,交換也是成功的。
代碼運行的結果,exchg1沒有交換a,b值;exchg2交換了a,b值,到了exchg,a,b的值似乎沒有交換,仍舊是a為4,b為6,剛開始以為代碼有問題,后來設置了斷點之后,發(fā)現(xiàn)代碼運行到exchg3(&a,&b)時,a=6,b=4了,所以代碼運行結果和初始值一樣的話,說明已經交換了a,b的值,至此說明代碼是沒有任何問題的。
相關文章
C語言使用openSSL庫AES模塊實現(xiàn)加密功能詳解
這篇文章主要介紹了C語言使用openSSL庫AES模塊實現(xiàn)加密功能,詳細分析了C語言加密的相關概念、原理及AES模塊加密具體實現(xiàn)技巧,需要的朋友可以參考下2017-05-05

