假设我有一个枚举,并且我希望每个枚举值与某个类型相关联。假设标准类型是double,如果我想要它是其他东西,我需要明确指定它。
Q1:这是实现此类事情的首选方法吗?
enum A {
v1,
v2,
v3
};
// for every value of A, the standard type is double
template<A a>
struct A_info {
typedef double type;
};
// other types for certain values can be specified using specialization
template<>
struct A_info<v2> {
typedef size_t type;
};
然后,假设我有一些函数模板,我想根据与枚举值相关联的类型调用函数:
template<typename T>
void foo() { /* do something */ }
template<A a>
void bar() {
foo< typename A_info<a>::type >();
}
这很好用。现在假设,我有另一个函数取决于可变参数模板列表,我想做类似上面的事情......
template<typename ... T>
void foo_multiple() { /* stuff */ }
template<A ... a>
void bar_multiple() {
foo_multiple< /* ??? */ > ();
}
Q2:如何实现?无论如何,这可能吗?
答案 0 :(得分:8)
只需使用您想要的模式展开可变参数包:
template<A ... a>
void bar_multiple() {
foo_multiple<typename A_info<a>::type...> ();
}