詳解C++的模板中typename關(guān)鍵字的用法
typename的使用場(chǎng)合
用處1, 用在模板定義里, 標(biāo)明其后的模板參數(shù)是類(lèi)型參數(shù)。
例如
template<typename T, typename Y> T foo(const T& t, const Y& y){//....}; templace<typename T> class CTest { private: T t; public: //... }
其實(shí),這里最常用的是使用關(guān)鍵字class,而且二者功能完全相同,這里的class和定義類(lèi)時(shí)的class完全是兩回事,C++當(dāng)時(shí)就是為了減少關(guān)鍵字,才使用了class。但最終卻不得不引入了typename,究竟是
什么原因呢?請(qǐng)看第二條,也就是typename的第二個(gè)用法。
用處2, 模板中標(biāo)明“內(nèi)嵌依賴(lài)類(lèi)型名”
這里有三個(gè)詞,內(nèi)嵌、依賴(lài)、類(lèi)型名。那么什么是“內(nèi)嵌依賴(lài)類(lèi)型名(nested dependent type name)”?
請(qǐng)看SGI STL里的一個(gè)例子, 只是STL中count范型算法的實(shí)現(xiàn):
template <class _InputIter, class _Tp> typename iterator_traits<_InputIter>::difference_type count(_InputIter __first, _InputIter __last, const _Tp& __value) { __STL_REQUIRES(_InputIter, _InputIterator); __STL_REQUIRES(typename iterator_traits<_InputIter>::value_type, _EqualityComparable); __STL_REQUIRES(_Tp, _EqualityComparable); typename iterator_traits<_InputIter>::difference_type __n = 0; for ( ; __first != __last; ++__first) if (*__first == __value) ++__n; return __n; }
這里有三個(gè)地方用到了typename:返回值、參數(shù)、變量定義。分別是:
typename iterator_traits<_InputIter>::difference_type typename iterator_traits<_InputIter>::value_type typename iterator_traits<_InputIter>::difference_type __n = 0;
difference_type, value_type就是依賴(lài)于_InputIter(模板類(lèi)型參數(shù))的類(lèi)型名。源碼如下:
template <class _Iterator> struct iterator_traits { typedef typename _Iterator::iterator_category iterator_category; typedef typename _Iterator::value_type value_type; typedef typename _Iterator::difference_type difference_type; typedef typename _Iterator::pointer pointer; typedef typename _Iterator::reference reference; };
內(nèi)嵌是指定義在類(lèi)名的定義中的。以上difference_type和value_type都是定義在iterator_traits中的。
依賴(lài)是指依賴(lài)于一個(gè)模板參數(shù)。 typename iterator_traits<_inputiter>::difference_type中difference_type依賴(lài)于模板參數(shù)_InputIter。
類(lèi)型名是指這里最終要指出的是個(gè)類(lèi)型名,而不是變量。例如iterator_traits<_inputiter>::difference_type完全有可能是類(lèi)iterator_traits<_inputiter> 類(lèi)里的一個(gè)static對(duì)象。而且當(dāng)我們這樣寫(xiě)的時(shí)候,C++默認(rèn)就是解釋為一個(gè)變量的。所以,為了和變量區(qū)分,必須使用typename告訴編譯器。
那么是不是所有的T::type_or_variable, 或者tmpl:type_or_variable都需要使用typename呢?不是,有以下兩個(gè)例外。
例外
(1)類(lèi)模板定義中的基類(lèi)列表。
例如
template<class T> class Derived: public Base<T>::XXX { ... }
(2)類(lèi)模板定義中的初始化列表。
Derived(int x) : Base<T>::xxx(x) { ... }
為什么這里不需要呢?因?yàn)榫幾g器知道這里需要的是類(lèi)型還是變量,(1)基類(lèi)列表里肯定是類(lèi)型名,(2)初始化列表里肯定是成員變量名。
typename和class的區(qū)別
在c++ Template中很多地方都用到了typename與class這兩個(gè)關(guān)鍵字,而且好像可以替換,是不是這兩個(gè)關(guān)鍵字完全一樣呢?
相信學(xué)習(xí)C++的人對(duì)class這個(gè)關(guān)鍵字都非常明白,class用于定義類(lèi),在模板引入c++后,最初定義模板的方法為: template<class T>......
在這里class關(guān)鍵字表明T是一個(gè)類(lèi)型,后來(lái)為了避免class在這兩個(gè)地方的使用可能給人帶來(lái)混淆,所以引入了typename這個(gè)關(guān)鍵字,它的作用同
class一樣表明后面的符號(hào)為一個(gè)類(lèi)型,這樣在定義模板的時(shí)候就可以使用下面的方式了:
template<typename T>......
在模板定義語(yǔ)法中關(guān)鍵字class與typename的作用完全一樣。
typename難道僅僅在模板定義中起作用嗎?其實(shí)不是這樣,typename另外一個(gè)作用為:使用嵌套依賴(lài)類(lèi)型(nested depended name),如下所示:
class MyArray { public: typedef int LengthType; ..... } template<class T> void MyMethod( T myarr ) { typedef typename T::LengthType LengthType; LengthType length = myarr.GetLength; }
這個(gè)時(shí)候typename的作用就是告訴c++編譯器,typename后面的字符串為一個(gè)類(lèi)型名稱(chēng),而不是成員函數(shù)或者成員變量,這個(gè)時(shí)候如果前面沒(méi)有
typename,編譯器沒(méi)有任何辦法知道T::LengthType是一個(gè)類(lèi)型還是一個(gè)成員名稱(chēng)(靜態(tài)數(shù)據(jù)成員或者靜態(tài)函數(shù)),所以編譯不能夠通過(guò)。
欄 目:C語(yǔ)言
下一篇:使用C語(yǔ)言的fork()函數(shù)在Linux中創(chuàng)建進(jìn)程的實(shí)例講解
本文標(biāo)題:詳解C++的模板中typename關(guān)鍵字的用法
本文地址:http://mengdiqiu.com.cn/a1/Cyuyan/2208.html
您可能感興趣的文章
- 04-02c語(yǔ)言的正則匹配函數(shù) c語(yǔ)言正則表達(dá)式函數(shù)庫(kù)
- 04-02c語(yǔ)言中對(duì)數(shù)函數(shù)的表達(dá)式 c語(yǔ)言中對(duì)數(shù)怎么表達(dá)
- 04-02c語(yǔ)言沒(méi)有round函數(shù) round c語(yǔ)言
- 04-02C語(yǔ)言中怎么打出三角函數(shù) c語(yǔ)言中怎么打出三角函數(shù)的值
- 01-10c語(yǔ)言求1+2+...+n的解決方法
- 01-10求子數(shù)組最大和的解決方法詳解
- 01-10深入理解約瑟夫環(huán)的數(shù)學(xué)優(yōu)化方法
- 01-10深入二叉樹(shù)兩個(gè)結(jié)點(diǎn)的最低共同父結(jié)點(diǎn)的詳解
- 01-10數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)- 解析最少換車(chē)次數(shù)的問(wèn)題詳解
- 01-10c語(yǔ)言 跳臺(tái)階問(wèn)題的解決方法


閱讀排行
- 1C語(yǔ)言 while語(yǔ)句的用法詳解
- 2java 實(shí)現(xiàn)簡(jiǎn)單圣誕樹(shù)的示例代碼(圣誕
- 3利用C語(yǔ)言實(shí)現(xiàn)“百馬百擔(dān)”問(wèn)題方法
- 4C語(yǔ)言中計(jì)算正弦的相關(guān)函數(shù)總結(jié)
- 5c語(yǔ)言計(jì)算三角形面積代碼
- 6什么是 WSH(腳本宿主)的詳細(xì)解釋
- 7C++ 中隨機(jī)函數(shù)random函數(shù)的使用方法
- 8正則表達(dá)式匹配各種特殊字符
- 9C語(yǔ)言十進(jìn)制轉(zhuǎn)二進(jìn)制代碼實(shí)例
- 10C語(yǔ)言查找數(shù)組里數(shù)字重復(fù)次數(shù)的方法
本欄相關(guān)
- 04-02c語(yǔ)言函數(shù)調(diào)用后清空內(nèi)存 c語(yǔ)言調(diào)用
- 04-02func函數(shù)+在C語(yǔ)言 func函數(shù)在c語(yǔ)言中
- 04-02c語(yǔ)言的正則匹配函數(shù) c語(yǔ)言正則表達(dá)
- 04-02c語(yǔ)言用函數(shù)寫(xiě)分段 用c語(yǔ)言表示分段
- 04-02c語(yǔ)言中對(duì)數(shù)函數(shù)的表達(dá)式 c語(yǔ)言中對(duì)
- 04-02c語(yǔ)言編寫(xiě)函數(shù)冒泡排序 c語(yǔ)言冒泡排
- 04-02c語(yǔ)言沒(méi)有round函數(shù) round c語(yǔ)言
- 04-02c語(yǔ)言分段函數(shù)怎么求 用c語(yǔ)言求分段
- 04-02C語(yǔ)言中怎么打出三角函數(shù) c語(yǔ)言中怎
- 04-02c語(yǔ)言調(diào)用函數(shù)求fibo C語(yǔ)言調(diào)用函數(shù)求
隨機(jī)閱讀
- 08-05dedecms(織夢(mèng))副欄目數(shù)量限制代碼修改
- 01-10delphi制作wav文件的方法
- 01-10C#中split用法實(shí)例總結(jié)
- 01-11ajax實(shí)現(xiàn)頁(yè)面的局部加載
- 08-05DEDE織夢(mèng)data目錄下的sessions文件夾有什
- 01-10SublimeText編譯C開(kāi)發(fā)環(huán)境設(shè)置
- 04-02jquery與jsp,用jquery
- 01-11Mac OSX 打開(kāi)原生自帶讀寫(xiě)NTFS功能(圖文
- 08-05織夢(mèng)dedecms什么時(shí)候用欄目交叉功能?
- 01-10使用C語(yǔ)言求解撲克牌的順子及n個(gè)骰子