遍历模板参数包,没有争论的专业化的作用是什么?

Traversing Template Parameter Packs, what is the role of the specialization which takes no argument?

本文关键字:专业化 作用 是什么 参数 遍历      更新时间:2023-10-16

我有以下一段代码:

template<typename... Types>
struct TupleSize;
template<typename Head, typename... Tail>
struct TupleSize<Head, Tail...>
{
static const size_t value = sizeof(Head) + TupleSize<Tail...>::value;
};
template<> struct TupleSize<>
{
static const size_t value = 0;
};

int main()
{
//consuming_templates();
//template_functions();
//variadic();
TupleSize<>::value;
TupleSize<int, double, char>::value;
getchar();
return 0;
}

我不明白以下角色是什么:

template<typename... Types>
struct TupleSize;

实际使用的地方,因为我知道TupleSize<>::value;返回0和另一段代码:

template<typename Head, typename... Tail>
struct TupleSize<Head, Tail...>
{
static const size_t value = sizeof(Head) + TupleSize<Tail...>::value;
};

用于拆分参数包并递归计算值。

这只是一个声明,如果是,为什么,如果不是在哪里使用。我能想象到的唯一情况是当递归达到其最终值时,即成为 TupleSize。但是我不明白模板结构类型怎么会这样存在,不应该是:

template<typename... Types>
struct TupleSize<typename... Types>; 

这只是一个声明,如果是,为什么,如果不是在哪里使用它。

它是主模板的声明,采用任意模板参数。它有两个专业;从不使用主模板,因为当指定 1 个模板参数或多个模板参数超过 1 个时,将选择第一个专用化;如果未指定模板参数(空(,则选择第二个专用化。