我正在尝试为非字符数组部分特化一个特征:
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在这种情况下不适用?
当然,我可以将非char和char的特化分开:
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在这种特殊情况下不起作用。
答案 0 :(得分:2)
检查主题“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)是正确的值。