Scott Meyers 在他的下一本书 EC + + 11中发布了 内容和地位。
他写道,书中的一个项目可能是 “在函数签名中避免使用 std::enable_if
”。
std::enable_if
可以用作函数参数、返回类型或类模板或函数模板参数,从重载解析中有条件地删除函数或类。
在 这个问题中显示了所有三种解决方案。
作为函数参数:
template<typename T>
struct Check1
{
template<typename U = T>
U read(typename std::enable_if<
std::is_same<U, int>::value >::type* = 0) { return 42; }
template<typename U = T>
U read(typename std::enable_if<
std::is_same<U, double>::value >::type* = 0) { return 3.14; }
};
作为模板参数:
template<typename T>
struct Check2
{
template<typename U = T, typename std::enable_if<
std::is_same<U, int>::value, int>::type = 0>
U read() { return 42; }
template<typename U = T, typename std::enable_if<
std::is_same<U, double>::value, int>::type = 0>
U read() { return 3.14; }
};
作为返回类型:
template<typename T>
struct Check3
{
template<typename U = T>
typename std::enable_if<std::is_same<U, int>::value, U>::type read() {
return 42;
}
template<typename U = T>
typename std::enable_if<std::is_same<U, double>::value, U>::type read() {
return 3.14;
}
};
std::enable_if
”将使用作为返回类型(这不是正常函数签名的一部分,而是模板专门化的一部分) ?