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