C++11模板元編程-std::enable_if示例詳解
C++11中引入了std::enable_if函數(shù),函數(shù)原型如下:
template< bool B, class T = void > struct enable_if;
可能的函數(shù)實現(xiàn):
template<bool B, class T = void> struct enable_if {}; template<class T> struct enable_if<true, T> { typedef T type; };
由上可知,只有當?shù)谝粋€模板參數(shù)為true時,enable_if會包含一個type=T的公有成員,否則沒有該公有成員。
頭文件:
#include <type_traits>
std::enable_if使用場景
1、限制模板函數(shù)的參數(shù)類型
在某些場景下,我們需要實現(xiàn)只有特定類型可以調(diào)用的模板函數(shù)。如下代碼所示,通過對返回值使用std::enable_if和在模板參數(shù)中使用std::enable_if均實現(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; }
當使用float類型參數(shù)調(diào)用函數(shù)時,程序會報錯:
error: no matching function for call to 'is_odd(float&)'
2. 模板類型偏特化
在使用模板編程時,可以利用std::enable_if的特性根據(jù)模板參數(shù)的不同特性進行不同的類型選擇。
如下所示,我們可以實現(xiàn)一個檢測變量是否為智能指針的實現(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é)
到此這篇關于C++11模板元編程-std::enable_if的文章就介紹到這了,更多相關C++11模板元編程-std::enable_if內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
詳解C語言中的fopen()函數(shù)和fdopen()函數(shù)
這篇文章主要介紹了詳解C語言中的fopen()函數(shù)和fdopen()函數(shù),注意其之間指針功能相關的區(qū)別,需要的朋友可以參考下2015-08-08c++ qsort 與sort 對結(jié)構(gòu)體排序?qū)嵗a
這篇文章主要介紹了c++ qsort 與sort 對結(jié)構(gòu)體排序?qū)嵗a,幫助大家更好的理解和學習c++,感興趣的朋友可以了解下2020-11-11C++?LeetCode1769移動所有球到每個盒子最小操作數(shù)示例
這篇文章主要為大家介紹了C++?LeetCode1769移動所有球到每個盒子所需最小操作數(shù)示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-12-12LeetCode題解C++生成每種字符都是奇數(shù)個的字符串
這篇文章主要為大家介紹了LeetCode題解C++生成每種字符都是奇數(shù)個的字符串示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-10-10VsCode安裝和配置c/c++環(huán)境小白教程(圖文)
本文主要介紹了VsCode安裝和配置c/c++環(huán)境小白教程,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-01-01