有没有一种方法可以推断列表的类型以避免必须传递列表应该是的参数类型,只需从第一个元素类型推断它。
template<typename T, T... Args>
struct Calc
{
// do stuff with Args
};
// Usage:
Calc<int, 1, 2, 3>::value;
typename<T... Args> Calc { }; // error T undefined
// Desired:
Calc<1, 2, 3>::value; // auto deduced T = int
Calc<1.0f, 2.0f, 3.0f>::value; // auto deduced T = float
有什么方法可以获得所需的行为,还是我必须将类型作为参数包含在内?
最佳答案
按照 Quentin 的建议,这里有一个类示例,它允许您为任何类型指定非类型可变参数,而无需明确拼写类型。但是, float 不能用作模板非类型参数。
以下编译:
#include <type_traits>
enum class Letters {
Alpha, Beta, Gamma
};
template<auto... Args>
struct Calc;
template<auto Arg1, auto... Args>
struct Calc<Arg1, Args...> {
using type = decltype(Arg1);
static type value;
};
template<>
struct Calc<> {
using type = void;
};
int main() {
//Calc<1, 2, 3>::value is int
static_assert(std::is_same_v<typename Calc<1, 2, 3>::type, int>);
//Calc<Letters::Alpha, Letters::Gamma>::value is Letters
static_assert(std::is_same_v<typename Calc<Letters::Alpha, Letters::Gamma>::type, Letters>);
//Calc<>::value does not exist as the type would be `void`
static_assert(std::is_same_v<typename Calc<>::type, void>);
return 0;
}
关于c++ - 推断可变参数模板的参数类型?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25922445/