国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > C++ > 正文

C++模版函數詳解

2020-01-26 14:14:44
字體:
來源:轉載
供稿:網友

C++中的模版總體可以分為兩大類:模版函數、模版類。本篇文章先寫模版函數,接下來會介紹模版類。

定義:模版函數是通用的函數描述,也就是說它們使用通用類型來定義,其中的通用類型可用具體類型替換。

代碼實例:

#include <iostream>//模版類的聲明template<typename T>void Swap(T& a,T& b);int main(){  int i = 10;  int j = 20;  std::cout<<"i=" << i << "," << "j=" <<j;  Swap(i,j);//生成 void Swap(int &,int&);  std::cout<<"i=" << i << "," << "j=" <<j;  double x = 11.5;  double y = 19.5;  std::cout<<"x=" << x << "," << "y=" <<y;  Swap(x,y);//編譯器生成 void Swap(double &,double&);  std::cout<<"x=" << x << "," << "y=" <<y;  return 0;}//模版類的定義template<typename T>void Swap(T& a,T& b){  T temp;  temp = a;  a = b;  b = temp;}

以上實例為最簡單的函數模版實例,編譯器會根據具體使用的類型生成相對應的函數。

重載的模版:

需要多個對不同的類型使用同一算法時可使用模版,如上代碼所示。但是并非所有的類型都使用相同的算法。為滿足這種需求,可以像重載常規函數定義那樣重載模版定義。和重載常規函數一樣,重載函數的特征表必須不同。代碼實例如下:

#include <iostream>//模版類的聲明template<typename T>void Swap(T& a,T& b);const int iCount = 5;template<typename T>void Swap(T* a,T*b,int n);int main(){  int i = 10;  int j = 20;  std::cout<<"i=" << i << "," << "j=" <<j;  Swap(i,j);//生成 void Swap(int &,int&)  std::cout<<"i=" << i << "," << "j=" <<j;  double x = 11.5;  double y = 19.5;  std::cout<<"x=" << x << "," << "y=" <<y;  Swap(x,y);//編譯器生成 void Swap(double &,double&);  std::cout<<"x=" << x << "," << "y=" <<y;  int d[iCount] = {0,1,2,3,4};  int e[iCount] = {5,6,7,8,9};  Swap(d,e,iCount);//匹配新的模版,進行數組的交換  return 0;}//模版類的定義template<typename T>void Swap(T& a,T& b){  T temp;  temp = a;  a = b;  b = temp;}template<typename T>void Swap(T* a,T*b,int n){  for (int i=0;i<iCount;++i)  {    T temp;    temp = a[i];    a[i] = b[i];    b[i] = temp;  }}

如上代碼新增了一個模版,用于交換兩個數組中的元素,原來的模版特征標為(T&,T&),新模版的特征標為(T[],T[]),int)。注意,在后一個模版中,最后一個參數的類型為具體類型(int),而不是通用類型,并非所有的模版參數都必須是模版參數類型。

顯示具體化:

對于給定的函數名,可以有非模版函數,模版函數和顯示具體化模版函數以及它們的重載版本。

顯示具體化的原型和定義應該以template<>打頭,并通過名稱來指出類型。

具體化將覆蓋常規模版,而非模版函數將覆蓋具體化和常規模版。

下面是用于交換Job結構的非模版函數,模版函數和具體化的原型。

void Swap(job &,job&);//非模版函數template <typename T>void Swap(T&,T&);//模版函數template <> void Swap<job>(job&,job&);//顯示具體化函數,其中Swap后的job參數可去掉,則函數簽名為template <> void Swap(job&,job&);

前面指出,如果有多個原型,編譯器在選擇原型時,非模版將優先于顯示具體化和模版版本,而顯示具體化將優先于使用模版生成的版本。

如下面的調用:

double u,v;
Swap(u,v);//使用通用的模版
job a,b;
swap (a,b)//使用顯示具體化版本。

實例化和具體化:

    為了進一步了解模版,必須理解術語實例化和具體化。記住,在代碼中包含函數模版本身并不會生成函數的定義,它只是一個用于生成函數定義的方案。編譯器使用模版為特定類型生成定義時,得到的是模版實例(instantiation)。例如:函數調用Swap(i,j),使編譯器生成一個Swap()的一個實例,該實例使用int類型。模版并非函數定義,但使用int的模版實例是函數定義。這種實例化方式被稱為隱式實例化,因為編譯器之所以知道需要定義,是由于程序調用Swap()時提供了int參數。

    現在編譯器還可以允許顯示實例化,這意味著可以直接命令編譯器生成特定的實例,如Swap<int>。其句法是,聲明所選的種類-用<>符號指示類型,并在聲明前加上關鍵字template:

template void Swap<int>(int,int);//顯示實例化

實現了這種特性的編譯器在看到上述聲明后,將使用Swap()模版生成一個int類型的實例。

與顯示實例化不同的是,顯示具體化使用下面兩個等價聲明的之一:

template <> void Swap<int>(int,int);template <> void Swap(int,int);

區別在于,這些聲明的意思是”不要使用Swap()模版來生成函數定義,而應該使用獨立的、專門的函數定義顯示為int類型生成函數定義。

注意:試圖在一個編程單元中使用同一種類型的顯示具體化與顯示實例化將出錯。

以上所述是小編給大家介紹的C++模版函數詳解,希望對大家有所幫助,如果大家有任何疑問歡迎給我留言。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 汉沽区| 安多县| 磴口县| 且末县| 刚察县| 三穗县| 夏河县| 贞丰县| 新蔡县| 嵊泗县| 巩留县| 金门县| 虹口区| 陕西省| 芒康县| 淮阳县| 新绛县| 都兰县| 镇雄县| 八宿县| 扎鲁特旗| 响水县| 凌源市| 吴旗县| 新巴尔虎右旗| 南乐县| 潍坊市| 萝北县| 贵南县| 定陶县| 美姑县| 玛多县| 米脂县| 新蔡县| 长丰县| 河源市| 崇仁县| 泾阳县| 江城| 梓潼县| 凤阳县|