缺少了C++模板真的不行嗎
首次進(jìn)行C++的初始學(xué)習(xí)時,首先接觸到的就是C++模板,在創(chuàng)建C++模板時出現(xiàn)了一些困難和難以理解的地方,比如向上類型轉(zhuǎn)換,向下類型轉(zhuǎn)換等相關(guān)麻煩,對于除類型之外,其余都相同的函數(shù),我們一般有3種解決辦法。
1、針對每個不同的類型重復(fù)地編寫函數(shù)實體(C語言的做法):
- T const& f(T const& a, T const& b)
- {
- return a + b; //1處
- }
- int g = f(1,2);
2、使用Object(Java的做法)或者void*缺點有兩個效率問題方面也有問題類型檢查問題
3、使用宏預(yù)處理機制
缺點:只是愚蠢的文本替換,而且也不會考慮作用域和類型安全。然而,應(yīng)用C++模板卻可以避免這些缺點,我們可以編寫:
優(yōu)點:
代碼簡潔優(yōu)雅,所有參數(shù)類型都以T來代替,真正實現(xiàn)了類型無關(guān)性。更好的類型安全性,所有的類型檢查都是在編譯期進(jìn)行,而且避免使用指針。不存在繼承,效率高。(1)沒有虛函數(shù);(2)所有的一切工作都是在編譯期完成,大大提高運行效率。目的:告訴編譯器如何做出最佳的選擇,而且這種選擇全部是在編譯期完成的。C++模板的機制:特化 和 實參演繹
- // traits/accumtraits3.hpp
- template
- lass AccumulationTraits;
- c template<>
- class AccumulationTraits {
- public:
- typedef int AccT;
- static AccT const zero = 0;
- };
- template<>
- class AccumulationTraits {
- public:
- typedef int AccT;
- static AccT const zero = 0;
- };
- template<>
- class AccumulationTraits {
- public:
- typedef long AccT;
- static AccT const zero = 0;
- };
- (2)policy:通常表現(xiàn)為某個函數(shù),指定的是一種行為
- class SumPolicy {
- public:
- template
- static void accumulate (T1& total, T2 const & value) {
- total += value;
- }
- };
- (3)trait和policy的用法:
- template >
- class Accum {
- public:
- typedef typename Traits::AccT AccT;
- static AccT accum (T const* beg, T const* end) {
- AccT total = Traits::zero();
- while (beg != end) {
- Policy::accumulate(total, *beg);
- ++beg;
- }
- return total;
- }
- };
優(yōu)點:由:全局特化->局部特化->基本C++模板,這種特化順序的選擇與匹配(重載解析規(guī)則)是由編譯器自動進(jìn)行的,無需人工參與??梢愿鶕?jù)不同的情況(諸如類型不同,條件不同),給出不同的實現(xiàn),從而獲得更加靈活的針對性??梢葬槍θ魏巫兓?,改善了程序的擴展性。
實參演繹
第1部分介紹了模板的基本概念,以教程的風(fēng)格來介紹這些基本概念。第2部分闡述了模板的語言細(xì)節(jié),可以作為一本基于模板的構(gòu)造的參考手冊。第3部分介紹了C++模板所支持的基本設(shè)計技術(shù),范圍覆蓋從微小的概念一直延伸到復(fù)雜的用法;一些技術(shù)在別的書籍都沒有出現(xiàn)過。第4部分基于前兩部分,深入討論了各種使用C++模板的普通應(yīng)用程序。
【編輯推薦】