C++?類(lèi)模板與成員函數(shù)模板示例解析
類(lèi)模板
前面以函數(shù)模板為例,介紹了具體化與實(shí)例化。那么對(duì)于類(lèi)模板,有什么不同呢?
類(lèi)包括成員變量和成員函數(shù),他們都可以包含類(lèi)模板的模板參數(shù)。而成員函數(shù)本身也可以是函數(shù)模板??聪旅娴膬蓚€(gè)類(lèi):
// 類(lèi)模板 template <typename T> class A { private: T t; public: void funcA(T t); }; template <typename T> void A<T>::funcA(T t) { cout << t; } // 成員函數(shù)模板 class B { private: int t; public: template <typename T> void funcB(T t); }; template <typename T> void B::funcB(T t) { cout << t; } int main() { A<int> a1; a1.funcA(1); A<char*> a2; a2.funcA("2"); B b; b.funcB(1); b.funcB("2"); }
類(lèi)模板A中包含成員函數(shù)funcA;類(lèi)B包含一個(gè)成員函數(shù)模板funcB。我們仔細(xì)看下二者的區(qū)別。
類(lèi)模板與成員函數(shù)模板的區(qū)別
首先,類(lèi)模版A中的成員函數(shù)的類(lèi)型可以用類(lèi)模板參數(shù)T,而成員函數(shù)模板做不到。
其次,在調(diào)用成員函數(shù)時(shí),類(lèi)模板A需要先指定一種類(lèi)型創(chuàng)建一個(gè)實(shí)例對(duì)象(如代碼中的a1),然后才能調(diào)用成員函數(shù),a1.funcA只能傳入int類(lèi)型參數(shù)。如果想傳char*類(lèi)型參數(shù),必須用char*創(chuàng)建一個(gè)實(shí)例(代碼中的a2)。
而對(duì)于類(lèi)B,則創(chuàng)建一個(gè)實(shí)例對(duì)象(b)之后,可以任何類(lèi)型作為參數(shù)來(lái)調(diào)用funcB。
只要明白了前面講的模板實(shí)例化,這里面的原因也很好理解。對(duì)于A來(lái)說(shuō),整個(gè)類(lèi)是一個(gè)模版,當(dāng)使用int類(lèi)型生成對(duì)象a1時(shí),也會(huì)對(duì)類(lèi)模板A進(jìn)行實(shí)例化,生成A類(lèi),其中所有的T都會(huì)替換為int,因此生成的類(lèi)只有一個(gè)成員函數(shù) void funcA(int)。如果想傳入char*,則必須實(shí)例化A<char*>這個(gè)類(lèi)。
而對(duì)于類(lèi)B,它本身只是一個(gè)普通類(lèi),只不過(guò)它包含一個(gè)成員函數(shù)模板。當(dāng)編譯器發(fā)現(xiàn)代碼中有調(diào)用這個(gè)成員函數(shù)funcB(int),編譯時(shí)會(huì)為funcB實(shí)例化;如果也有調(diào)用funcB(char*),則會(huì)為B生成funcB<char*>成員函數(shù)。也就是說(shuō),類(lèi)B的成員函數(shù)的數(shù)量不是確定的,是根據(jù)funcB被調(diào)用的情況來(lái)決定到底實(shí)例化出多少個(gè)成員函數(shù)。
以上就是C++ 類(lèi)模板與成員函數(shù)模板示例解析的詳細(xì)內(nèi)容,更多關(guān)于C++ 類(lèi)模板成員函數(shù)模板的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
C語(yǔ)言中回調(diào)函數(shù)的含義與使用場(chǎng)景詳解
這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言中回調(diào)函數(shù)的含義與使用場(chǎng)景,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來(lái)幫助2022-03-03C++用一棵紅黑樹(shù)同時(shí)封裝出set與map的實(shí)現(xiàn)代碼
set中存儲(chǔ)的一般為鍵K即可,而map存儲(chǔ)的一般都是鍵值對(duì)KV,也就是說(shuō)他們結(jié)構(gòu)是不同的,那么我們?nèi)绾尾拍苡靡活w紅黑樹(shù)同時(shí)封裝出set與map兩種容器呢,那么接下來(lái)我們具體地來(lái)研究下STL庫(kù)中是怎樣實(shí)現(xiàn)的,并且進(jìn)行模擬實(shí)現(xiàn),需要的朋友可以參考下2024-03-03VS2019調(diào)試C語(yǔ)言程序(監(jiān)視操作)的詳細(xì)步驟
在很多時(shí)候我們?cè)趯?xiě)程序的過(guò)程中會(huì)發(fā)現(xiàn)一些非編程錯(cuò)誤的問(wèn)題,這樣的問(wèn)題很難直接分辨出來(lái),但是我們可以用調(diào)試了一步一步的模擬程序運(yùn)行的過(guò)程,來(lái)找出程序的錯(cuò)誤,下面這篇文章主要給大家介紹了關(guān)于VS2019調(diào)試C語(yǔ)言程序(監(jiān)視操作)的詳細(xì)步驟,需要的朋友可以參考下2022-11-11