c++ - 如果模板类型是可实例化的,则执行某些操作

标签 c++ templates sfinae

如果我可以实例化某个模板类,我想使用 SFINAE 模式来执行一些代码。让我们想象一下:

//Only instantiable with types T for which T.x() is ok:
template <class T>
class TemplateClass
{
  T t;
public:
  void foo() { 
    t.x(); 
  }
}

template <class T>
class User
{
  void foo()
  { 
    "if TemplateClass<T> is ok then do something else do nothing" 
  }
}

我该怎么做?

非常感谢!

编辑:基于我尝试过的 edA-qa mort-ora-y 的回答:

template <class T>
struct TemplateClass
{
    T t;
    void foo() { t.x(); }

    static const bool value = true;

};
struct A {};
struct B { void x() {} };

template <class T>
struct User
{
    template<typename M>
    typename boost::enable_if<TemplateClass<M> >::type func( ) 
    { 
        std::cout << "enabled\n";
    }

    template<typename M>
    typename boost::disable_if<TemplateClass<M> >::type func( ) 
    { 
        std::cout << "disabled\n";
    }


    void foo()
    {
        func<TemplateClass<T> >();
    }

};

User<A> a;
a.foo();

User<B> b;
b.foo();

但这会返回“enabled enabled”。我错过了什么?

最佳答案

你应该看看 boost boost/utility/enable_if.hpp header 和关联的元/模板编程代码。

这里最简单的方法是拥有两个版本的 foo 函数,都是模板函数。其中一个函数将使用 enable_if 结构,另一个将使用 disable_if 结构。

我相信您可以在 boost 网站上找到更好的示例,但像这样:

template<typename M>
typename boost::enable_if<Template<M>>::type func( ) { }

只有在 Template 是有效类型时才会定义此函数。因为你总是想编译你需要对应的函数,当它无效时要调用的函数:

template<typename M>
typename boost::disable_if<Template<M>>::type func( ) { }

我不确定您是否可以在单个模板中在此模式中定义两个成员函数,而无需将它们都设为模板函数。我想您可以定义两个模板函数并将默认模板参数设置为 T。

希望对您有所帮助。

关于c++ - 如果模板类型是可实例化的,则执行某些操作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4095188/

相关文章:

c++ - 在 Windows 中从 OpenGL 窗口捕获视频

c++ - 函数模板部分特化 - 有什么解决方法吗?

c++ - 为什么我的 SFINAE 开关不工作?

c++ - 无法在 VS .NET 2008 中使用 boost::enable_if 专门化成员函数模板

c++ - 交叉引用和循环依赖。 header 间接包含自身

c++ - 错误链接 2019 c++

模板构造函数中的 C++ 链接器错误 : "unresolved external symbol"

c++ - 从继承自模板的 dll 导出类

c++ - 如何为元组参数专门化一个函数?

c++ - 实现 std::variant 转换构造函数 - 或者:如何从参数包中找到从任何 T 到 Ti 的所有转换的第一个重载