假设我有一个类模板 template <typename T> class X
是否可以使用类型特征或类似技术来调用 T 的(静态)方法,但前提是类型 T 声明了此类方法,例如像这样的东西:
template <typename T>
class X {
static void foo(){
if(has_method(T,bar)) //Something like this
T::bar(); //If T has no bar() method, then foo does nothing
}
};
最佳答案
template <typename T>
class X {
public:
static void foo() {
foo_impl(static_cast<T*>(nullptr));
}
private:
// foo_impl #1
template <typename U>
static auto foo_impl(U*) -> decltype(U::bar(), void()) {
U::bar();
}
// foo_impl #2
static void foo_impl(...) {}
};
由于 SFINAE 规则,当 U::bar()
不是有效表达式且 foo_impl 时,
#2 被调用。如果 foo_impl
#1 不在重载集中foo_impl
#1 的类型推导确实成功,那么它总是比省略号更好的转换。
Ideone 演示:http://ideone.com/UKVmIB
关于使用类型特征调用 C++ 条件函数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14689699/