首页 > 解决方案 > 在有效和无效的非类型参数包之间进行选择

问题描述

我试图复制这个问题的答案:在有效和无效类型之间进行选择,但我不知道如何使用非类型模板参数包来实现这一点。

对于上下文,我正在尝试实现一个模板化的多维数组

template<typename T, std::size_t CurrentDim, std::size_t... Dims>
class Array {

在课堂上,如果 Dims 为空,我试图创建一个类型为 T 的数组,如果 Dims 不为空,则创建一个类型为 Array<T, Dims...> 的数组。例如:

using SubType = std::conditional<sizeof...(Dims) == 0, T, Array<T, Dims...>>;        
SubType array[CurrentDim];

问题是,如果 Dims 为空,则条件失败

error: too few template arguments for class template 'Array'

...因为条件的第二部分是无效的,即使检查为假,也会被评估。有谁知道如何实现这一目标?我知道我可以专门化我的 Array 类,但我相信这需要我复制所有代码?

这是另一个相关问题:std::conditional compile-time branch evaluation

标签: c++c++11

解决方案


一种方法是部分专业化:

template<typename T, std::size_t CurrentDim, std::size_t... Dims>
class Array {
  Array<T, Dims...> array[CurrentDim];
};

template<typename T, std::size_t Dim>
class Array<T, Dim> {
  T array[Dim];
};

推荐阅读