首页 >后端开发 >C++ >为什么 SFINAE 对于类模板成员函数失败?

为什么 SFINAE 对于类模板成员函数失败?

Mary-Kate Olsen
Mary-Kate Olsen原创
2024-11-04 22:18:02853浏览

Why Does SFINAE Fail for Class Template Member Functions?

SFINAE 类模板成员函数失败

替换失败,不是错误 (SFINAE) 机制,常用于模板元编程,当应用于类模板成员函数时,似乎表现出特殊的行为。

问题

考虑以下代码片段:

<code class="cpp">#include <type_traits>

struct A{};
struct B{};

template <typename T>
struct Foo
{
    // Conditional enable bar() for T == A
    typename std::enable_if<std::is_same<T, A>::value>::type
    bar()
    {}

    // Conditional enable bar() for T == B
    typename std::enable_if<std::is_same<T, B>::value>::type
    bar()
    {}
};</code>

此代码尝试在 Foo 类模板中定义 bar() 的两个重载,并使用 SFINAE 根据 T 的值有条件地启用每个重载。但是,代码无法编译,并出现以下错误:

<code class="cpp">error: 'typename std::enable_if<std::is_same<T, B>::value>::type Foo<T>::bar()' cannot be overloaded</code>

说明

SFINAE 通常用于启用或禁用基于模板参数的模板专业化。但是,SFINAE 仅适用于 推导的 模板参数,这意味着在重载解析期间自动推导的参数。对于成员函数,模板参数不是推导的,而是在实例化类时显式指定的。因此,SFINAE 不适用于成员函数。

解决方案

解决这个问题主要有两种方法:

  • 使用函数模板:为每个重载定义单独的函数模板,如下所示:
<code class="cpp">template <typename T>
void bar(Foo<T><- A) {}

template <typename T>
void bar(Foo<T><- B) {}
  • 使用显式类模板特化:定义单独的函数模板每个重载的类模板,如下所示:
<code class="cpp">template <typename> struct Foo;

template <> struct Foo<A> { void bar() {} };
template <> struct Foo<B> { void bar() {} };</code>

以上是为什么 SFINAE 对于类模板成员函数失败?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn