问题描述
我尝试在部分专业领域中将CTAD与SFINAE结合使用,但是除非我添加了看似无用的推论指南,否则它不会编译。背后的原因/局限是什么?
template<typename T,typename Enable = void>
struct A;
template<typename T>
struct A< T,std::enable_if_t<std::is_arithmetic_v<T>>>
{
A(T) { std::cout << "Numerical"; }
};
template<typename T>
struct A<T,std::enable_if_t<!std::is_arithmetic_v<T>>>
{
A(T) { std::cout << "Other"; }
};
template<typename T>
A(T)->A<T>; //Need to have this,otherwise doesn't compile
int main()
{
A a{ 1 };
}
解决方法
隐式生成的推导指南仅反映主模板的构造函数,而不是专业化模板。
如果您摆脱了一种专业化,然后将代码从其中转移到主模板中,它将起作用:
template<typename T,typename Enable = void>
struct A
{
A(T) { std::cout << "Other\n"; }
};
template<typename T>
struct A< T,std::enable_if_t<std::is_arithmetic_v<T>>>
{
A(T) { std::cout << "Numerical\n"; }
};