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 《型別 形參表》可以包含基本資料型別可以包含類型別。
請看以下程式:
[cpp]view plain
copy
#include
using
std::cout;
using
std::endl;
//宣告乙個函式模版,用來比較輸入的兩個相同資料型別的引數的大小,class也可以被typename代替,
//t可以被任何字母或者數字代替。
template
<
class
t>
t min(t x,t y)
void
main( )
程式執行結果:
1 、模板類和過載函式一起使用
兩者一起使用時,先考慮過載函式,後考慮模板類,如過再找不到,就考慮型別轉換,可能會帶來精度的變化。
[cpp]view plain
copy
#include "iostream"
using
namespace
std ;
//函式模板
template
<
class
t>
const
t max(t a , t b)
intmax(
intx ,
inty)
intmax(
char
x ,
inty)
intmax(
intx ,
char
y)
intmain(
void
)
2 、類模板
(1)類模板的具體格式
template
class a
在類定義體外定義的成員函式,應該使用函式模板。
[cpp]view plain
copy
/*類模板,但是在類外定義成員函式的時候,需要使用函式模板
*/#include
using
namespace
std ;
template
<
class
t>
class
base
t geta()
//類內定義
void
seta(t c);
};
template
<
class
t>
//模板在類外的定義
void
base::seta(t c)
intmain(
void
)
注意成員函式在類外定義的情況。
3 、模板類
主要指的是 stl 模板類
from:
C 引用 自學筆記可能有錯
引用就是某一變數 目標 的乙個別名,對引用的操作與對變數直接操作完全一樣。型別識別符號 引用名 目標變數名 char m n 引用變數 和 被引用的變數公用乙個空間,也就是說改變m或n m和n都會改變,在宣告引用的時候必須要初始化。int main int main float fn2 float ...
C 型別轉換 自學筆記 可能有誤
c風格的型別轉換 type b type a c 型別轉換提供了4中型別轉換操作符來對應不同場合的應用 1 static cast 靜態型別轉換 2 reinterpreter cast 重新解釋型別 3 dynamic cast 命名上理解是動態型別轉換。如子類和父類之間的多型型別轉換 4 con...
c 模板類學習
1 模板的概念 我們已經學過過載 overloading 對過載函式而言,c 的檢查機制能通過函式引數的不同及所屬類的不同。正確的呼叫過載函式。例如,為求兩個數的最大值,我們定義max 函式需要對不同的資料型別分別定義不同過載 overload 版本。函式1.int max int x,int y ...