C++中的模板变量
Template template variadics in C++
是否可以使用模板模板变量来捕获传递的模板参数本身就是模板的所有情况?
我一直在使用模板为一些基于模板的方法生成调试输出。首先,我创建了一个通用处理程序,然后将其专门用于本地类型:
template<typename... PARAMS> struct TypeList{};
template<typename TYPE> inline void ntype(ostream &out, TypeList<TYPE>) {
out << typeid(TYPE).name();
}
template<> inline void ntype(ostream &out, TypeList<int>) {
out << "int";
}
...
然后我尝试添加第二个模板格式来捕获正在传递的模板类型:
template<typename ... SUB, template<typename...> class TYPE> void ntype(ostream &out, TypeList<TYPE<SUB...> >) {
ntype(out, TypeList<typename TYPE>());
out << '<';
subtype(out, TypeList<SUB...>());
out << '>';
}
其中subtype是一个模板方法,设计用于在参数列表中递归,依次将每个方法应用于ntype()。
问题是,当我试图用某种东西来称呼它时,效果是:
ntype<SomeClass<int> >(out, TypeList<SomeClass<int> >());
它只匹配通用的第一个模板函数-没有编译错误,但从不匹配模板模板版本。我确信这只是我缺乏理解,但当涉及到模板模板的清晰示例时,谷歌的结果似乎非常薄弱,而对于可变模板参数来说,结果更为薄弱。
有人能解释我的尝试是否可能吗?如果可能,我做错了什么?
我似乎只是有一个拼写错误——我在函数声明中的一个TypeLists后面添加了(),可能是凌晨3点从函数调用中复制粘贴的,这导致了不匹配。
所以,如果有人想知道,是的,这是可能的,上面的方法是完全可以接受的
相关文章:
- 如何创建一个CMake变量,除非显式重写,否则使用默认值
- 将成员变量添加到共享库中的类中,不会破坏二进制兼容性吗
- 将数组的地址分配给变量并删除
- 为"adjacent"变量赋值时出现问题
- enum是C++中的宏变量还是整数变量
- 在全局变量中保存类的实例以重新创建类(创建"backup")
- 用C++中的一个变量定义一个常量
- 具有奇怪重复模板模式的派生类中的成员变量已损坏
- 你能重载对象变量名本身返回的内容吗
- 内置函数可查看CPP中的成员变量
- 是否可以初始化不可复制类型的成员变量(或基类)
- 尝试通过多个向量访问变量时,向量下标超出范围
- 试图让变量检查数组中的某些内容
- Cpp-Tuple使用带有变量的get
- 将包含C样式数组的对象初始化为成员变量(C++)
- 当vector是tje全局变量时,c++中vector的内存管理
- 通过多个头文件使用常量变量
- std::threads可以从Windows DLL中的全局变量创建/销毁吗?
- 执行函数时导致崩溃的变量
- 变量没有改变?通过向量的函数调用