自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

C++類模板特化基本概念概述

開發(fā) 后端
C++類模板特化的一些相關(guān)操作基本上都是在類名后進(jìn)行的。我們將特化的步驟分為全局特化與局部特化這兩種。下面將對其進(jìn)行詳細(xì)介紹。

我們在上一篇文章中為大家詳細(xì)介紹了C++類模板的具體應(yīng)用方式,相比朋友們應(yīng)該可以從中對類模板有一個充份的認(rèn)識。那么C++類模板特化又是如何進(jìn)行的呢?其實,C++類模板特化被描述為一個和重載類似的概念。

我的理解是,特化允許我們對某些特殊的參數(shù)(這里就是類型)進(jìn)行特殊的處理。C++類模板特化的處理都是在類名后面做文章的。特化分為全局特化和局部特化。對于全局特化,書中的例子是希望對于Stack< T>模板,如果參數(shù)為std::string的類型,就用deque作為容器來處理,而其他的保持不變。因此,我們需要對Stack< T>模板作std::string的特化處理。代碼如下:

 

  1. #include < deque> 
  2. #include < string> 
  3. #include < stdexcept> 
  4. #include "Stack.h"  
  5. template< > 
  6. class Stack< std::string>{  
  7. private:  
  8. std::deque< std::string> elems;  
  9. public:  
  10. void push(std::string const&);  
  11. void pop();  
  12. std::string top() const;  
  13. bool empty() const{  
  14. return elems.empty();  
  15. }  
  16. };  
  17. void Stack< std::string>::push(std::string const& elem)  
  18. {  
  19. elems.push_back(elem);  
  20. }  
  21. void Stack< std::string>::pop()  
  22. {  
  23. if(elems.empty())  
  24. {  
  25. throw std::out_of_range("Stack< std::string>::pop()==> empty stack.");  
  26. }  
  27. elems.pop_back();  
  28. }  
  29. std::string Stack< std::string>::top() const  
  30. {  
  31. if(elems.empty())  
  32. {  
  33. throw std::out_of_range("Stack< std::string>::pop()==> empty stack.");  
  34. }  
  35. return elems.back();  

注意到C++類模板特化的定義和普通的類模板完全不一樣了。主要區(qū)別有:#t#

特化類模板的前面加上了template< >,沒有指定參數(shù)。而是在類名后面指定了類型參數(shù)。

在函數(shù)的定義里面,原來的類型T全部換成了特化的類型std::string。實際上,完全可以根據(jù)特殊需要重寫成員函數(shù)。甚至可以定義另外的函數(shù)。

將上面的源代碼加入到工程中,編譯運(yùn)行。就會發(fā)現(xiàn)當(dāng)使用std::string去實例化stack的時候?qū)嶋H上調(diào)用的是StringStack文件中的"重載"版本。各個方法的調(diào)用也一樣。也就是說,特化實際上是要求對特定的參數(shù)施行特殊的處理。從這個方面來說和重載確實很類似。

但是,我認(rèn)為特征化和重載還是有區(qū)別的。試想有一個函數(shù)Func(int, int),另外一個函數(shù)對它進(jìn)行重載為Func(string, string)。在實際上我們也可以說int的Func重載了string的Func,這是相互的。但是特化卻不能這么說。因為特化是對某種類型的特殊處理,我們可以說特化模板重載了某個模板,但是不能說某個模板重載了特化的模板。這是單方向的。另外,如果,我們不需要Func(int, int)函數(shù),我們完全可以把它刪去。但是C++類模板特化不能離開它依賴的類模板單獨存在。在上面的例子中,如果刪除Stack.h文件,StringStack.h文件的定義就會出錯。

StringStack是Stack模板的特化。但是他們之間的聯(lián)系其實不是那么緊密,除了名字上以外。例如,Stack模板中的成員函數(shù)不必非得在StringStack中出現(xiàn);同理,StringStack中的函數(shù)也不必是Stack中的函數(shù)。也就是說,特化的模板類可以根據(jù)自己的需要完全重寫指定的模板函數(shù),也可以棄原來模板函數(shù)中的成員不用,另外定義成員函數(shù)。這方面沒有限制。

在理解了全局的特化以后,在來看局部的特化就很容易明白了。局部特化是要求在指定的條件下使用指定的類模板的重載版本。

責(zé)任編輯:曹凱 來源: 博客園
相關(guān)推薦

2010-02-05 17:34:37

C++函數(shù)模板

2010-02-02 13:41:01

C++類繼承

2010-02-06 15:58:10

C++集合初始化

2010-02-04 17:39:48

C++字符串類型

2010-02-04 14:01:43

C++非類型類模板參數(shù)

2010-02-03 13:22:07

C++時間

2010-02-02 10:33:22

C++引用

2010-02-05 12:57:20

C++ kdevelo

2010-02-02 15:30:05

C++ include

2010-02-03 11:11:18

C++類型轉(zhuǎn)換

2010-02-03 14:36:47

C++仿函數(shù)

2010-02-01 17:24:41

C++循環(huán)語句

2022-01-17 10:12:47

C++‘模板元編程

2010-02-06 14:04:58

C++內(nèi)存使用機(jī)制

2010-02-04 10:08:00

C++靜態(tài)成員函數(shù)

2010-02-01 14:07:12

C++多態(tài)性

2010-02-04 17:32:43

C++中C風(fēng)格字符串

2010-02-02 10:07:59

C++全局函數(shù)

2011-03-28 11:05:17

ODBC

2017-03-27 20:42:17

遷移學(xué)習(xí)人工智能機(jī)器學(xué)習(xí)
點贊
收藏

51CTO技術(shù)棧公眾號