【问题标题】:template template parameter of unknown type未知类型的模板模板参数
【发布时间】:2025-11-24 21:50:01
【问题描述】:

尝试在以下代码中提取模板参数值:

template<std::size_t SIZE>
class Foo {};

template <template<std::size_t> class T, std::size_t K>
auto extractSize(const T<K>&) {
    return K;
}

int main() {
    Foo<6> f1;
    Foo<13> f2;
    std::cout << extractSize(f1) << std::endl;
    std::cout << extractSize(f2) << std::endl;
}

(作为问题的答案: Extract C++ template parameters)。

但是,有没有办法做到这一点不知道模板参数的类型。类似的东西(下面的代码无法编译...):

template <template<class SIZE_TYPE> class T, SIZE_TYPE K>
auto extractSize(const T<K>&) {
    return K;
}

上面的编译错误,是:

error: unknown type name 'SIZE_TYPE'
template <template<class SIZE_TYPE> class T, SIZE_TYPE K>
                                             ^

【问题讨论】:

  • 您是否尝试将 '''typename SIZE_TYPE''' 放在列表的开头?
  • @RobertAndrzejuk 添加类型名 SIZE_TYPE fails with C++14。它确实有效with C++17 - 但如果我们在 C++17 中,Rakete1111 提出的auto 的解决方案会更简单。

标签: c++ c++11 templates c++14


【解决方案1】:

auto 来救援!

template <template<auto> class T, auto K>
auto extractSize(const T<K>&) {
    return K;
}

这样会自动推断您作为模板参数传入的值的类型。

【讨论】:

  • 这不取决于Foo 接受auto 非类型参数,而不是std::size_t?这里的扣除规则我不清楚
  • 确实很好:)
  • 酷。运行良好for C++17,不适用于 C++14。对 C++11/14 有什么建议吗?
  • @AmirKirsh auto C++17 中引入了模板参数,C++14 没有这样的解决方案。
  • 在 C++17 之前没有办法,假设您使用的是符合标准的编译器而不是从内存中键入 (smh)。我自己的尝试在timsong-cpp.github.io/cppwp/n4140/temp#deduct.type-5.3 失败了