Да, это не типовой параметр. Вы можете иметь несколько видов параметров шаблона
- Параметры типа.
- Типы
- Шаблоны (только шаблоны классов и псевдонимов, без функций или шаблонов переменных)
- Нетипичные параметры
- Pointers
- Ссылки
- Выражения из интегральных констант
То, что у вас есть, имеет последний вид. Это константа времени компиляции (так называемое константное выражение) и имеет тип integer или перечисление. Изучив его в стандарте, мне пришлось переместить шаблоны классов в раздел типов - даже если шаблоны не являются типами. Но они все же называются тип-параметрами для целей описания этих видов. Вы можете иметь указатели (а также указатели членов) и ссылки на объекты / функции, которые имеют внешнюю связь (те, на которые можно ссылаться из других объектных файлов и чей адрес уникален во всей программе). Примеры:
Параметр типа шаблона:
template<typename T>
struct Container {
T t;
};
// pass type "long" as argument.
Container<long> test;
Целочисленный параметр шаблона:
template<unsigned int S>
struct Vector {
unsigned char bytes[S];
};
// pass 3 as argument.
Vector<3> test;
Параметр указателя шаблона (передача указателя на функцию)
template<void (*F)()>
struct FunctionWrapper {
static void call_it() { F(); }
};
// pass address of function do_it as argument.
void do_it() { }
FunctionWrapper<&do_it> test;
Ссылочный параметр шаблона (с передачей целого числа)
template<int &A>
struct SillyExample {
static void do_it() { A = 10; }
};
// pass flag as argument
int flag;
SillyExample<flag> test;
Параметр шаблона шаблона.
template<template<typename T> class AllocatePolicy>
struct Pool {
void allocate(size_t n) {
int *p = AllocatePolicy<int>::allocate(n);
}
};
// pass the template "allocator" as argument.
template<typename T>
struct allocator { static T * allocate(size_t n) { return 0; } };
Pool<allocator> test;
Шаблон без каких-либо параметров невозможен. Но шаблон без какого-либо явного аргумента возможен - он имеет аргументы по умолчанию:
template<unsigned int SIZE = 3>
struct Vector {
unsigned char buffer[SIZE];
};
Vector<> test;
Синтаксически template<>
зарезервировано для обозначения явной специализации шаблона вместо шаблона без параметров:
template<>
struct Vector<3> {
// alternative definition for SIZE == 3
};