使用类型特征调用 C++ 条件函数

标签 c++ templates type-traits

假设我有一个类模板 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 时,foo_impl #1 不在重载集中 #2 被调用。如果 foo_impl #1 的类型推导确实成功,那么它总是比省略号更好的转换。

Ideone 演示:http://ideone.com/UKVmIB

关于使用类型特征调用 C++ 条件函数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14689699/

相关文章:

c++ - 如何使用std::auto_ptr实现协方差赋值?

c++ - 在模板函数中将 Ref<> 用于通用特征矩阵

c++ - 通过模板方法的迭代器返回集合

rust - 当特征界限添加到自身上时意味着什么?

检查可变参数模板中没有重复类型的 C++ 概念

c++ - xcode: 我在哪里可以设置这个链接器标志 '-v' ?

c++ - 不使用预处理器调用 Clang

c++ - 'sum' 中没有名为 'std::slice_array<int>' 的成员

c++ - 无法根据隐式构造的参数推导模板参数

c++ - 获取第一个模板参数的稳健方法