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

深刻解析C++中的函數模板和函數的默許參數

編輯:關於C++

深刻解析C++中的函數模板和函數的默許參數。本站提示廣大學習愛好者:(深刻解析C++中的函數模板和函數的默許參數)文章只能為提供參考,不一定能成為您想要的結果。以下是深刻解析C++中的函數模板和函數的默許參數正文


C++函數模板
我們曉得,數據或數值可以經由過程函數參數傳遞,在函數界說時它們是未知的,只要在產生函數挪用時能力肯定其值。這就是數據的參數化。

其實,數據類型也能夠經由過程參數來傳遞,在函數界說是可以不指明詳細的數據類型,當產生函數挪用時,編譯器可以依據傳入的參數主動肯定數據類型。這就是數據類型參數化。

所謂函數模板,現實上是樹立一個通用函數,其前往值類型和形參類型不詳細指定,用一個虛擬的類型來取代(現實上是用一個標識符來占位)。這個通用函數就稱為函數模板(Function Template)。但凡函數體雷同的函數都可以用這個模板來取代,不用界說多個函數,只需在模板中界說一次便可。在挪用函數時體系會用實參的類型來代替模板中的虛擬類型,從而完成了分歧函數的功效。

【例】將上節代碼改成經由過程函數模板來完成。

#include <iostream>
using namespace std;
template<typename T> //模板聲明,個中T為類型參數
T max(T a, T b, T c) //界說一個通用函數,用T作虛擬的類型名
{
  if(b>a) a=b;
  if(c>a) a=c;
  return a;
}
int main( )
{
  //求三個整數的最年夜值
  int i1, i2, i3, i_max;
  cin >> i1 >> i2 >> i3;
  i_max = max(i1,i2,i3);
  cout << "i_max=" << i_max << endl;
  //求三個浮點數的最年夜值
  double d1, d2, d3, d_max;
  cin >> d1 >> d2 >> d3;
  d_max = max(d1,d2,d3);
  cout << "d_max=" << d_max << endl;
  //求三個長整型數的最年夜值
  long g1, g2, g3, g_max;
  cin >> g1 >> g2 >> g3;
  g_max = max(g1,g2,g3);
  cout << "g_max=" << g_max << endl;
}

運轉成果與上節雷同。

界說函數模板的普通情勢為:

  template < typename T>


    通用函數界說  通用函數界說

  template <class T>


    通用函數界說  通用函數界說

在樹立函數模板時,只需將例4.5法式中界說的第一個函數首部的int改成T便可。即用虛擬的類型名T取代詳細的數據類型。在對法式停止編譯時,碰到第13行挪用函數max(i1, i2, i3),編譯體系會將函數名max與模板max相婚配,將實參的類型代替了函數模板中的虛擬類型T。此時相當於已界說了一個函數:

int max(int a, int b, int c)
{
  if(b>a) a=b;
  if(c>a) a=c;
  return a;
}


然後挪用它。前面兩行(14,15行)的情形相似。

類型參數可以不只一個,可以依據須要肯定個數。如:

  template <class T1, typename T2>


可以看到,用函數模板比函數重載更便利,法式更簡練。但應留意它只實用於函數的參數個數雷同而類型分歧,且函數體雷同的情形,假如參數的個數分歧,則不克不及用函數模板。

C++函數的默許參數
普通情形下,在函數挪用時形參從實參那邊獲得值,是以實參的個數應與形參雷同。有時屢次挪用統一函數時用異樣的實參,C++供給簡略的處置方法,給形參一個默許值,如許形參就不用必定要從實參取值了。若有一函數聲明:

  float area(float r=6.5);


指定r的默許值為6.5,假如在挪用此函數時,確認r的值為6.5,則可以不用給出實參的值,如:

  area( ); //相當於area(6.5);


假如不想使形參取此默許值,則經由過程實參另行給出。如:

  area(7.5); //形參獲得的值為7.5,而不是6.5


這類辦法比擬靈巧,可以簡化編程,進步運轉效力。

假如有多個形參,可使每一個形參有一個默許值,也能夠只對一部門形參指定默許值,另外一部門形參不指定默許值。若有一個求圓柱體體積的函數,形參h代表圓柱體的高,r為圓柱體半徑。函數原型以下:

  float volume(float h, float r=12.5); //只對形參r指定默許值12.5


函數挪用可以采取以下情勢:

  volume(45.6); //相當於volume(45.6,12.5)
  volume(34.2, 10.4); //h的值為34.2,r的值為10.4

實介入形參的聯合是從左至右次序停止的。是以指定默許值的參數必需放在形參表列中的最右端,不然失足。例如:

  void f1(float a, int b=0, int c, char d=′a′); //不准確
  void f2(float a, int c, int b=0, char d=′a′); //准確


假如挪用下面的f2函數,可以采用上面的情勢:

  f2(3.5, 5, 3, ′x′) //形參的值全體從實參獲得
  f2(3.5, 5, 3) //最初一個形參的值取默許值′a′
  f2(3.5, 5) //最初兩個形參的值取默許值,b=0,d=′a′


可以看到,在挪用有默許參數的函數時,實參的個數可以與形參的個數分歧,實參未給定的,從形參的默許值獲得值。應用這一特征,可使函數的應用加倍靈巧。例如例4.7求2個數或3個數中的最年夜數。也能夠不消重載函數,而改用帶有默許參數的函數。

【例】求2個或3個正整數中的最年夜數,用帶有默許參數的函數完成。

#include <iostream>
using namespace std;
int main( )
{
  int max(int a, int b, int c=0);//函數聲明,形參c有默許值
  int a,b,c;
  cin>>a>>b>>c;
  cout<<"max(a,b,c)="<<max(a,b,c)<<endl;//輸入3個數中的最年夜者
  cout<<"max(a,b)="<<max(a,b)<<endl; //輸入2個數中的最年夜者
  return 0;
}
int max(int a,int b,int c) //函數界說
{
  if(b>a) a=b;
  if(c>a) a=c;
  return a;
}

運轉情形以下:

14 -56 135↙
max(a,b,c)=135
max(a,b)=14

在應用帶有默許參數的函數時有兩點要留意:
假如函數的界說在函數挪用之前,則應在函數界說中給出默許值。假如函數的界說在函數挪用以後,則在函數挪用之前須要有函數聲明,此時必需在函數聲明中給出默許值,在函數界說時可以不給出默許值(如例4.8)。
一個函數不克不及既作為重載函數,又作為有默許參數的函數。由於當挪用函數時假如少寫一個參數,體系沒法剖斷是應用重載函數照樣應用默許參數的函數,湧現二義性,體系沒法履行。

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