Scott Meyers 发布了他的下一本书 EC++11 的内容和状态。他写道,书中的一项内容可能是“Avoid std::enable_if
in function signatures”。
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
”涉及用作返回类型(这不是正常函数签名的一部分,而是模板特化的一部分)? - 成员函数模板和非成员函数模板有什么区别吗?