C++11模板元編程-std::enable_if示例詳解
C++11中引入了std::enable_if函數(shù),函數(shù)原型如下:
template< bool B, class T = void > struct enable_if;
可能的函數(shù)實(shí)現(xiàn):
template<bool B, class T = void> struct enable_if {}; template<class T> struct enable_if<true, T> { typedef T type; };
由上可知,只有當(dāng)?shù)谝粋€(gè)模板參數(shù)為true時(shí),enable_if會(huì)包含一個(gè)type=T的公有成員,否則沒有該公有成員。
頭文件:
#include <type_traits>
std::enable_if使用場(chǎng)景
1、限制模板函數(shù)的參數(shù)類型
在某些場(chǎng)景下,我們需要實(shí)現(xiàn)只有特定類型可以調(diào)用的模板函數(shù)。如下代碼所示,通過對(duì)返回值使用std::enable_if和在模板參數(shù)中使用std::enable_if均實(shí)現(xiàn)了只允許整形參數(shù)調(diào)用函數(shù)的功能。
// enable_if example: two ways of using enable_if #include <iostream> #include <type_traits> // 1. the return type (bool) is only valid if T is an integral type: template <class T> typename std::enable_if<std::is_integral<T>::value,bool>::type is_odd (T i) {return bool(i%2);} // 2. the second template argument is only valid if T is an integral type: template < class T, class = typename std::enable_if<std::is_integral<T>::value>::type> bool is_even (T i) {return !bool(i%2);} int main() { short int i = 1; // code does not compile if type of i is not integral std::cout << std::boolalpha; std::cout << "i is odd: " << is_odd(i) << std::endl; std::cout << "i is even: " << is_even(i) << std::endl; return 0; }
當(dāng)使用float類型參數(shù)調(diào)用函數(shù)時(shí),程序會(huì)報(bào)錯(cuò):
error: no matching function for call to 'is_odd(float&)'
2. 模板類型偏特化
在使用模板編程時(shí),可以利用std::enable_if的特性根據(jù)模板參數(shù)的不同特性進(jìn)行不同的類型選擇。
如下所示,我們可以實(shí)現(xiàn)一個(gè)檢測(cè)變量是否為智能指針的實(shí)現(xiàn):
#include <iostream> #include <type_traits> #include <memory> template <typename T> struct is_smart_pointer_helper : public std::false_type {}; template <typename T> struct is_smart_pointer_helper<std::shared_ptr<T> > : public std::true_type {}; template <typename T> struct is_smart_pointer_helper<std::unique_ptr<T> > : public std::true_type {}; template <typename T> struct is_smart_pointer_helper<std::weak_ptr<T> > : public std::true_type {}; template <typename T> struct is_smart_pointer : public is_smart_pointer_helper<typename std::remove_cv<T>::type> {}; template <typename T> typename std::enable_if<is_smart_pointer<T>::value,void>::type check_smart_pointer(const T& t) { std::cout << "is smart pointer" << std::endl; } template <typename T> typename std::enable_if<!is_smart_pointer<T>::value,void>::type check_smart_pointer(const T& t) { std::cout << "not smart pointer" << std::endl; } int main() { int* p(new int(2)); std::shared_ptr<int> pp(new int(2)); std::unique_ptr<int> upp(new int(4)); check_smart_pointer(p); check_smart_pointer(pp); check_smart_pointer(upp); return 0; }
程序輸出:
not smart pointer
is smart pointer
is smart pointer
參考材料
http://www.cplusplus.com/reference/type_traits/enable_if/
https://en.cppreference.com/w/cpp/types/enable_if
總結(jié)
到此這篇關(guān)于C++11模板元編程-std::enable_if的文章就介紹到這了,更多相關(guān)C++11模板元編程-std::enable_if內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
詳解C語言中的fopen()函數(shù)和fdopen()函數(shù)
這篇文章主要介紹了詳解C語言中的fopen()函數(shù)和fdopen()函數(shù),注意其之間指針功能相關(guān)的區(qū)別,需要的朋友可以參考下2015-08-08c++ qsort 與sort 對(duì)結(jié)構(gòu)體排序?qū)嵗a
這篇文章主要介紹了c++ qsort 與sort 對(duì)結(jié)構(gòu)體排序?qū)嵗a,幫助大家更好的理解和學(xué)習(xí)c++,感興趣的朋友可以了解下2020-11-11C++實(shí)現(xiàn)俄羅斯方塊(windows API)
這篇文章主要為大家詳細(xì)介紹了C++實(shí)現(xiàn)俄羅斯方塊,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-06-06C++?LeetCode1769移動(dòng)所有球到每個(gè)盒子最小操作數(shù)示例
這篇文章主要為大家介紹了C++?LeetCode1769移動(dòng)所有球到每個(gè)盒子所需最小操作數(shù)示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-12-12LeetCode題解C++生成每種字符都是奇數(shù)個(gè)的字符串
這篇文章主要為大家介紹了LeetCode題解C++生成每種字符都是奇數(shù)個(gè)的字符串示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-10-10C語言實(shí)踐設(shè)計(jì)開發(fā)飛機(jī)游戲
飛機(jī)大戰(zhàn)想必是很多人童年時(shí)期的經(jīng)典游戲,我們依舊能記得抱個(gè)老人機(jī)娛樂的場(chǎng)景,下面這篇文章主要給大家介紹了關(guān)于如何利用C語言寫一個(gè)簡(jiǎn)單的飛機(jī)大戰(zhàn)小游戲的相關(guān)資料,需要的朋友可以參考下2022-02-02VsCode安裝和配置c/c++環(huán)境小白教程(圖文)
本文主要介紹了VsCode安裝和配置c/c++環(huán)境小白教程,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-01-01