CTAD не может вывести аргумент шаблона с помощью SFINAE в частичной специализации

Я пробовал использовать 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 };
}

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"; }
};
Другие вопросы по тегам