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