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

更快更好的制定C++函數參數

編輯:C++入門知識

C++函數是C ++語言程序的主要組成部分,一個內部函數可以調用其他函數。在設計良好的程序中,每個函數都有特定的目的,這也證實了C++語言的面向對象的特點。

但是,如果實參表達式中帶有副作用的運算符時,就有可能產生由於求值順序不同而造成了二義性。例如:int z = add_int(++x, x+y);,這樣,在不同的編譯器就有可能生產不同的結果。

設置參數的默認值

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

  1. add_int(15) 

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

  1. int add_int(int x, int 10); 

在給某個參數指定默認值是,不僅可以是一個數值,而且還可以是任意復雜的表達式。使用數組作C++函數參數,數組作函數參數可以分為如下三種情況:(這三種情況的結果相同,只是所采用的調用機制不同)

1. 形參和實參都用數組

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

2. 形參和實參都用對應數組的指針

C++語言中,數組名被規定為是一個指針,該指針便是指向該數組的首元素的指針,國為它的值是該數組首元素的地址值,因此,數組名是一個常量指針。實際中,形參和實參一個用指針,另一個用數組也是可以的。在使用指針時可以用數組名,也可以用另外定義的指向數組的指針。

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

如何對數組類型使用引用方式,這裡先做如下說明:先用類型定義語句定義一個int型的數組類型,然後,使用array來定義數組和引用。

示例:

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

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

  1. 簡介學習C++總結之談
  2. 對C++庫函數進行學習探索總結筆記
  3. C++類庫設計的基本構思與方法
  4. C++語言真的還有市場價值?
  5. C++類庫設計的基本構思與方法

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