1. 模板的概念。
我們已經學過過載(overloading),對過載函式而言,c++的檢查機制能通過函式引數的不同及所屬類的不同。正確的呼叫過載函式。例如,為求兩個數的最大值,我們定義max()函式需要對不同的資料型別分別定義不同過載(overload)版本。
//函式1.
int max(int x,int y);
//函式2.
float max( float x,float y)
//函式3.
double max(double x,double y)
但如果在主函式中,我們分別定義了 char a,b; 那麼在執行max(a,b);時 程式就會出錯,因為我們沒有定義char型別的過載版本。
現在,我們再重新審視上述的max()函式,它們都具有同樣的功能,即求兩個數的最大值,能否只寫一套**解決這個問題呢?這樣就會避免因過載函式定義不全面而帶來的呼叫錯誤。為解決上述問題c++引入模板機制,模板定義:模板就是實現**重用機制的一種工具,它可以實現型別引數化,即把型別定義為引數,從而實現了真正的**可重用性。模版可以分為兩類,乙個是函式模版,另外乙個是類模版。
2. 函式模板的寫法
函式模板的一般形式如下:
template
返回型別 函式名(形參表)
說明: template是乙個宣告模板的關鍵字,表示宣告乙個模板關鍵字class不能省略,如果型別形參多餘乙個 ,每個形參前都要加class 《型別 形參表》可以包含基本資料型別可以包含類型別.
請看以下程式:
#include
using std::cout;
using std::endl;
//宣告乙個函式模版,用來比較輸入的兩個相同資料型別的引數的大小,class也可以被typename代替,
//t可以被任何字母或者數字代替。
template
t min(t x,t y)
程式執行結果:
程式分析:main()函式中定義了兩個整型變數n1 , n2 兩個雙精度型別變數d1 , d2然後呼叫min( n1, n2); 即例項化函式模板t min(t x, t y)其中t為int型,求出n1,n2中的最小值.同理呼叫min(d1,d2)時,求出d1,d2中的最小值.
3. 類模板的寫法
定義乙個類模板:
template < class或者也可以用typename t >
class類名{
//類定義...... };
說明:其中,template是宣告各模板的關鍵字,表示宣告乙個模板,模板引數可以是乙個,也可以是多個。
例如:定義乙個類模板:
// classtemplate.h
#ifndef classtemplate_hh
#define classtemplate_hh
template
class myclass;
//這是建構函式
//注意這些格式
template
myclass::myclass(t1 a,t2 b):i(a),j(b){}
//這是void show();
template
void myclass::show()
#endif
// test.cpp
#include
#include "classtemplate.h"
using std::cout;
using std::endl;
void main()
最後結果顯示:
4.非型別模版引數
一般來說,非型別模板引數可以是常整數(包括列舉)或者指向外部鏈結物件的指標。
那麼就是說,浮點數是不行的,指向內部鏈結物件的指標是不行的。
template
class stack;
int main() ;
C 模板的概念
我們已經學過過載 overloading 對過載函式而言,c 的檢查機制能通過函式引數的不同及所屬類的不同。正確的呼叫過載函式。例如,為求兩個數的最大值,我們定義max 函式需要對不同的資料型別分別定義不同過載 overload 版本。函式1.int max int x,int y 函式2.floa...
C 中模板特化的概念
1.模板的特化 c 中經常為了避免重複的編碼而需要使用到模板,這是c 泛型程式設計不可或缺的利器。然而通常又有一些特殊的情況,不能直接使用泛型模板展開實現,這時就需要針對某個特殊的型別或者是某一類特殊的型別,而實現乙個特例模板 即模板特化。通常會使用到模板特化的有 應該也只能有 類模板和函式模板。a...
模板的概念
1.模板的概念。我們已經學過過載 overloading 對過載函式而言,c 的檢查機制能通過函式引數的不同及所屬類的不同。正確的呼叫過載函式。例如,為求兩個數的最大值,我們定義max 函式需要對不同的資料型別分別定義不同過載 overload 版本。函式1.int max int x,int y ...