詳解c++11新特性之模板的改進
C++11關(guān)于模板有一些細節(jié)的改進:
- 模板的右尖括號
- 模板的別名
- 函數(shù)模板的默認模板參數(shù)
模板的右尖括號
C++11之前是不允許兩個右尖括號出現(xiàn)的,會被認為是右移操作符,所以需要中間加個空格進行分割,避免發(fā)生編譯錯誤。
int main() { std::vector<std::vector<int>> a; // error std::vector<std::vector<int> > b; // ok }
這個我之前都不知道,我開始學編程的時候就已經(jīng)是C++11的時代啦。
模板的別名
C++11引入了using,可以輕松的定義別名,而不是使用繁瑣的typedef。
typedef std::vector<std::vector<int>> vvi; // before c++11 using vvi = std::vector<std::vector<int>>; // c++11
使用using明顯簡潔并且易讀,大家可能之前也見過使用typedef定義函數(shù)指針之類的操作,那爛代碼我就不列出來了,反正我是看不懂也不想看...以后都可以使用using,額還是列出來吧。
typedef void (*func)(int, int); // 啥玩意,看不懂 using func = void (*)(int, int); // 起碼比typedef容易看的懂吧
上面的代碼使用using起碼比typedef容易看的懂一些吧,但是我還是看不懂,因為我從來不用這種來表示函數(shù)指針,用std::function()、std::bind()、std::placeholder()、lambda表達式它不香嗎。
函數(shù)模板的默認模板參數(shù)
C++11之前只有類模板支持默認模板參數(shù),函數(shù)模板是不支持默認模板參數(shù)的,C++11后都支持。
template <typename T, typename U=int> class A { T value; }; template <typename T=int, typename U> // error class A { T value; };
類模板的默認模板參數(shù)必須從右往左定義,而函數(shù)模板則沒有這個限制。
template <typename R, typename U=int> R func1(U val) { return val; } template <typename R=int, typename U> R func2(U val) { return val; } int main() { cout << func1<int, double>(99.9) << endl; // 99 cout << func1<double, double>(99.9) << endl; // 99.9 cout << func1<double>(99.9) << endl; // 99.9 cout << func1<int>(99.9) << endl; // 99 cout << func2<int, double>(99.9) << endl; // 99 cout << func1<double, double>(99.9) << endl; // 99.9 cout << func2<double>(99.9) << endl; // 99.9 cout << func2<int>(99.9) << endl; // 99 return 0; }
對于函數(shù)模板,參數(shù)的填充順序是從左到右的。
關(guān)于C++11對于模板的改進就講到這里,請繼續(xù)關(guān)注~
參考資料
《深入應(yīng)用C++11:代碼優(yōu)化與工程級應(yīng)用》
https://blog.csdn.net/tennysonsky/article/details/77817027
到此這篇關(guān)于c++11新特性之模板的改進的文章就介紹到這了,更多相關(guān)c++11新特性之模板的改進內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C語言實現(xiàn)系統(tǒng)關(guān)機注銷功能
這篇文章主要為大家詳細介紹了C語言實現(xiàn)系統(tǒng)關(guān)機注銷功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2020-02-02LeetCode 單調(diào)棧內(nèi)容小結(jié)
這篇文章主要介紹了LeetCode 單調(diào)棧內(nèi)容小結(jié),本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下2021-07-07C語言詳解如何實現(xiàn)堆及堆的結(jié)構(gòu)與接口
堆是計算機科學中一類特殊的數(shù)據(jù)結(jié)構(gòu)的統(tǒng)稱,通常是一個可以被看做一棵完全二叉樹的數(shù)組對象。而堆排序是利用堆這種數(shù)據(jù)結(jié)構(gòu)所設(shè)計的一種排序算法。本文將詳細介紹堆的結(jié)構(gòu)與接口,需要的可以參考一下2022-04-04