C++ 模板专用化和模板参数数量
c++ template specialization and number of template arguments
我刚刚开始学习模板,我正在经历一个实现TypeList的示例,并看到了TypeList的Length方法的实现。
template <class TList> struct Length;
template <> struct Length<NullType>
{
enum { value = 0 };
};
template <class T, class U>
struct Length< Typelist<T, U> >
{
enum { value = 1 + Length<U>::value };
};
我的问题是主长度模板只有 1 个参数 (TList(,但专业化有 2 个参数。这怎么可能,我在其他地方读到专业化的参数数量较少
以下专业化是每种类型的Length
专业化Typelist<T, U>
。这对模板参数描述了显然需要两个参数TypeList<T, U>
。它不直接定义 Length
的模板参数。
template <class T, class U>
struct Length< Typelist<T, U> >
{
enum { value = 1 + Length<U>::value };
};
对于template <class TList> struct Length;
,专用化定义了TList = Typelist<T, U>
以及T
和U
是类型。
第一个:
template <> struct Length<NullType>
是完全专业化,第二个:
template <class T, class U>
struct Length< Typelist<T, U> >
是部分专业化。
通过完全专业化,您可以给出要专业化的确切类型。通过部分专用化,您可以允许遵守某些限制的所有类型,在这种情况下,它能够创建类型:Typelist<T, U>
,还必须提供两个模板类型参数。
有关更多详细信息,请参阅此处:
http://en.cppreference.com/w/cpp/language/template_specializationhttp://en.cppreference.com/w/cpp/language/partial_specialization
我的问题是主长度模板只有 1 个参数 (TList(,但专业化有 2 个参数。这怎么可能,
这就是部分专用化所允许的,模板参数列表必须不同(有关详细信息,请参阅上面的链接(,但它们必须提供与主模板期望的相同数量的类型参数(Length< Typelist<T, U> >
(。
相关文章:
- C++函数模板需要 &for 数组参数
- C++ 数组参数不起作用
- 使用数组参数进行函数专用化
- 为什么我的数组参数的方法无法正常工作?(C )
- SWIG - Java 代理类数组参数
- 在 gcc 中使用数组参数编译外部"c"代码
- 从 VB6 调用的 C++ DLL 函数中的输出数组参数
- 基于模板参数的模板类力数的参数
- 如何根据数组参数项类型重载 IDL 中的函数
- 引用谷歌测试/模拟框架中的数组参数
- 比特菲尔德,标志数为参数
- C++将数组参数传递给函数
- 字符星形数组参数未正确终止
- 如何将德尔菲的"字符串数组"参数翻译成C++?
- 为什么 gcc 无法推断数组参数的模板化大小?(C++11)
- 使用 const char 数组参数分析 constexpr 显示运行时执行
- C++指针数组参数
- 固定大小的多维数组参数
- 为什么数组参数被视为常量数组
- 如何在pgsql中格式化数组参数