程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> C語言 >> C++ >> 關於C++ >> 淺談C++函數的參數

淺談C++函數的參數

編輯:關於C++

函數參數的求值順序

當一個函數帶有多個參數時,C++語言沒有規定在函數調用時實參的求值順序。而編譯器根據對代碼進行優化的需要自行規定對實參的求值順序。有的編譯器規定自左至右,有的編譯器規定自右至左,這種對求值順序的不同規定,對一般參數來講沒有影響。但是,如果實參表達式中帶有副作用的運算符時,就有可能產生由於求值順序不同而造成了二義性。例如:intz = add_int(++x,x+y);,這樣,在不同的編譯器就有可能生產不同的結果。

設置參數的默認值

在C++語言中,允許在函數的說明或定義時給一個或多個參數指定默認值。但是,要求在一個指定了默認值的參數的右邊,不能出現沒有指定默認值的參數。例如:

intadd_int(int x, int10);

在上述對函數add_int()的說明中,對該函數的最右邊的一個參數指定了默認值。

在函數調用時,編譯器按從左至右的順序將實參與形參結合,當實參的數目不足時,編譯器將按同樣的順序用說明中或定義中的默認值來補足所缺少的實參。例如,如有下列的函數調用表達式:    add_int(15)

它將與下列調用表達式:

add_int(15,10)

是等價的。

在給某個參數指定默認值是,不僅可以是一個數值,而且還可以是任意復雜的表達式。

使用數組作函數參數

數組作函數參數可以分為如下三種情況:(這三種情況的結果相同,只是所采用的調用機制不同)

1.形參和實參都用數組

調用函數的實參用數組名,被調用函數的形參用數組,這種調用的機制是形參和實參共用內存中的同一個數組。因此,在被調用函數中改變了數組中某個無素的值,對調用函數該數組的該元素值也被改變,因為它們是共用同一個數組。   2.形參和實參都用對應數組的指針

在C++中,數組名被規定為是一個指針,該指針便是指向該數組的首元素的指針,國為它的值是該數組首元素的地址值,因此,數組名是一個常量指針。

實際中,形參和實參一個用指針,另一個用數組也是可以的。在使用指針時可以用數組名,也可以用另外定義的指向數組的指針。

3.實參用數組名形參用引用

如何對數組類型使用引用方式,這裡先做如下說明:先用類型定義語句定義一個int型的數組類型,如下所示:

typedefint array[8];

然後,使用array來定義數組和引用。

示例:

#include
typedef int array[8];
int a[8] ={1, 3, 5, 7, 9, 11, 13};
void fun(array &b, int n)
{
for(int i=0;i b[7]+=b[i];
}
void main()
{
int m=8;
fun(a,m);
cout<}

該程序中,在fun()函數中,使用了引用作形參,調用時所對應的實參應該是一個數組名,這裡的引用是給數組起個別名。在fun()函數中對數組b的操作,就相當於b所引用數組a的操作。在C++中,常用這種調用方式。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved