c++ - CTAD 无法在部分特化中使用 SFINAE 推导出模板参数

标签 c++ templates c++17 ctad

我尝试在部分特化中使用 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 };
}

最佳答案

隐式生成的推导指南仅反射(reflect)主模板的构造函数,而不是特化的构造函数。

如果您摆脱其中一种特化,并将代码从其中移至主模板,它将起作用:

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"; }
};

关于c++ - CTAD 无法在部分特化中使用 SFINAE 推导出模板参数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/64184732/

相关文章:

c++ - "stable_sort()ing"C++ 中的 STL <列表>

Drupal 7 Views - 如何在自定义模板中访问未格式化的 $row 变量?

c++ - 使用默认模板参数推导模板参数失败

c++ - MacOS 上的 QSettings 奇怪行为

c++ - 关闭我的 DISLIN 小部件会导致我的整个程序关闭

模板 <char*, char*> 对象的 c++ 排序 vector

c# - C++ 是否支持单个泛型方法而不是泛型类?

c++ - g++ std::visit 泄漏到全局命名空间?

c++ - 模板模板类谓词在部分特化中不起作用

c++ - 为什么结构对象不是类型?