unt*_*gam 6 c++ void sfinae enable-if c++11
我试图std::enable_if在C++ 11中更好地理解并且一直在尝试编写一个最小的例子:一个A具有成员函数的类,void foo()它具有基于T类模板中的类型的不同实现.
下面的代码给出了期望的结果,但我还没有完全理解它.为什么版本V2有效,但不是V1?为什么U需要"冗余"类型?
#include <iostream>
#include <type_traits>
template <typename T>
class A {
public:
A(T x) : a_(x) {}
// Enable this function if T == int
/* V1 */ // template < typename std::enable_if<std::is_same<T,int>::value,int>::type = 0>
/* V2 */ template <typename U=T, typename std::enable_if<std::is_same<U,int>::value,int>::type = 0>
void foo() { std::cout << "\nINT: " << a_ << "\n"; }
// Enable this function if T == double
template <typename U=T, typename std::enable_if<std::is_same<U,double>::value,int>::type = 0>
void foo() { std::cout << "\nDOUBLE: " << a_ << "\n"; }
private:
T a_;
};
int main() {
A<int> aInt(1); aInt.foo();
A<double> aDouble(3.14); aDouble.foo();
return 0;
}
Run Code Online (Sandbox Code Playgroud)
有没有更好的方法来实现所需的结果,即void foo()基于类模板参数具有不同的函数实现?
我知道这不能完全回答您的问题,但它可能会给您更多的想法和理解如何使用std::enable_if.
您可以将 foo 成员函数替换为以下内容并具有相同的功能:
template<typename U=T> typename std::enable_if<std::is_same<U,int>::value>::type
foo(){ /* enabled when T is type int */ }
template<typename U=T> typename std::enable_if<std::is_same<U,double>::value>::type
foo(){ /* enabled when T is type double */ }
Run Code Online (Sandbox Code Playgroud)
不久前,我对enable_if的工作原理有了很好的了解,但遗憾的是我忘记了它的大部分复杂性,只记得更实用的使用方法。
| 归档时间: |
|
| 查看次数: |
1820 次 |
| 最近记录: |