【问题标题】:inheriting from an enable_if'd base从 enable_if 的基础继承
【发布时间】:2011-09-12 14:46:53
【问题描述】:

我正在尝试为非字符数组部分专门化一个特征:

template<typename T>
struct is_container : std::false_type {};

template<typename T, unsigned N>
struct is_container<T[N]>
: std::enable_if<!std::is_same<T, char>::value, std::true_type>::type {};

Visual Studio 2010 给了我一个 C2039(type 不是 enable_if... 的元素)。但是,SFINAE 不应该只是在这里触底而不是给出编译器错误吗?或者SFINAE不适用于这种情况?

当然,我可以将非字符和字符的特化分开:

template<typename T>
struct is_container : std::false_type {};

template<typename T, unsigned N>
struct is_container<T[N]> : std::true_type {};

template<unsigned N>
struct is_container<char[N]> : std::false_type {};

但我真的很想知道为什么 SFINAE 在这种特殊情况下不起作用。

【问题讨论】:

  • 好吧,我认为typename 前面需要std::enable_if,因为依赖类型,但我不会把它作为答案,因为这只是猜测!
  • @Arak:不。typename 在这种情况下不是必需的。在搜索基类时,编译器会在一开始就排除所有非类型。看到这个:stackoverflow.com/questions/4347730/…
  • 你能指定你想要做什么,例如您尝试实例化is_container 以使您期望SFINAE 启动的上下文是什么?另一方面,如果你只需要有条件的基础,像std::conditional 这样的东西会更合适。
  • 可能是硬错误的问题,你试过boost::lazy_enable_if吗?

标签: c++ templates sfinae template-meta-programming enable-if


【解决方案1】:

查看主题“3.1 启用模板类专业化”,网址为 http://www.boost.org/doc/libs/1_47_0/libs/utility/enable_if.html

编辑:以防 boost.org 链接失效...

3.1 启用模板类特化 可以使用 enable_if 启用或禁用类模板特化。需要为启动器表达式添加一个额外的模板参数。此参数具有默认值 void。例如:

template <class T, class Enable = void> 
class A { ... };

template <class T>
class A<T, typename enable_if<is_integral<T> >::type> { ... };

template <class T>
class A<T, typename enable_if<is_float<T> >::type> { ... };

用任何整数类型实例化 A 匹配第一个特化,而任何浮点类型匹配第二个特化。所有其他类型与主模板匹配。条件可以是依赖于类的模板参数的任何编译时布尔表达式。再次注意,不需要 enable_if 的第二个参数;默认值(void)是正确的值。

【讨论】:

  • 我非常怀疑 boost.org 的链接会失效,但无论如何我会发布完整的答案。
  • 我也是,尽管他们过去已经重组过一次网站 :)
  • 请注意boost::is_floatstd::is_floating_point 非常相似。
猜你喜欢
  • 1970-01-01
  • 2010-10-21
  • 1970-01-01
  • 2011-03-03
  • 1970-01-01
  • 2011-04-24
  • 1970-01-01
  • 2011-06-18
  • 1970-01-01
相关资源
最近更新 更多