【问题标题】:Enable_if as template parameterEnable_if 作为模板参数
【发布时间】:2019-04-24 10:09:48
【问题描述】:

请告诉我为什么this answer 有效。

  1. enable_if 发生了什么我们可以在此之后省略它? (Foo struct 的进一步使用不需要模板参数中的 enable_if)
  2. 代码不应该是这样的吗:

原始版本:

template <typename Policy,
          typename = typename std::enable_if<std::is_base_of<BasePolicy, Policy>::value>::type >
struct Foo;

template <typename Policy>
struct Foo {
    Foo();
};

template <typename Policy>
Foo<Policy>::Foo() {
}

编辑版本:

template <typename Policy,
          typename = typename std::enable_if<std::is_base_of<BasePolicy, Policy>::value>::type >
struct Foo;

template <typename Policy>
struct Foo<Policy> {  // <Policy> added!
    Foo();
};

template <typename Policy>
Foo<Policy>::Foo() {
}

【问题讨论】:

  • “enable_if 之后我们可以省略它会发生什么?” - 之后呢? ...请你把你的问题说清楚一点吗?
  • 如果您还包括原始代码以使差异更容易访问会很好
  • 我说清楚了,加上原代码
  • 谁说原版必须工作?这是作者的错误。
  • 它的前面有&lt;Policy&gt;,但作者在新版本中删除了它。检查编辑历史记录和 cmets。

标签: c++ c++11 templates enable-if


【解决方案1】:

发生了这样的事情:

  1. 作者发布了工作代码(&lt;Policy&gt; 存在);

  2. cmet中有一些讨论导致作者编辑代码,搞错了(&lt;Policy&gt;被删除);

  3. 我纠正了放回丢失的&lt;Policy&gt;的错误。


谁能解释一下为什么即使是编辑过的版本也有效?

当您尝试实例化 Foo&lt;T&gt; 时,编译器会考虑使用默认模板参数的声明。评估默认参数,如果std::is_base_of&lt;BasePolicy, Policy&gt;::valuefalse,那么enable_if 会产生一个SFINAE 友好的错误。

如果std::is_base_of&lt;BasePolicy, Policy&gt;::valuetrue,则选择部分特化。

template <typename Policy>
struct Foo<Policy> {
    Foo() { } 
};

// is equivalent to

template <typename Policy>
struct Foo<Policy, void> {
    Foo() { } 
};

上述特化是等价的,因为typename std::enable_if&lt;true&gt;::type 默认为void

【讨论】:

  • 感谢您的关注。你能解释一下为什么正确的版本有效吗?我的意思是 C++ 的哪个特性使这种神奇发生?
  • @MOHRE:添加了解释
  • 你是Policy
  • @SombreroChicken:你只是一个BasePolicy
猜你喜欢
  • 2012-08-07
  • 1970-01-01
  • 2012-06-18
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多