您需要一些模板元编程机制来实现这一点。
实现参数分派的最简单方法是利用包含压缩编译时整数序列的表达式的包扩展。需要模板机制来构建这样的序列(有关标准化此类序列的提案的更多信息,请参见此答案末尾的备注)。
假设有一个类(模板)index_range
封装了一个编译时整数范围 [M, N)和一个类(模板)index_list
封装了一个编译时整数列表,这就是你将如何使用它们:
template<typename T, typename... Args>
struct foo
{
tuple<Args...> args;
// Allows deducing an index list argument pack
template<size_t... Is>
T gen(index_list<Is...> const&)
{
return T(get<Is>(args)...); // This is the core of the mechanism
}
T gen()
{
return gen(
index_range<0, sizeof...(Args)>() // Builds an index list
);
}
};
这是index_range
and的可能实现index_list
:
//===============================================================================
// META-FUNCTIONS FOR CREATING INDEX LISTS
// The structure that encapsulates index lists
template <size_t... Is>
struct index_list
{
};
// Collects internal details for generating index ranges [MIN, MAX)
namespace detail
{
// Declare primary template for index range builder
template <size_t MIN, size_t N, size_t... Is>
struct range_builder;
// Base step
template <size_t MIN, size_t... Is>
struct range_builder<MIN, MIN, Is...>
{
typedef index_list<Is...> type;
};
// Induction step
template <size_t MIN, size_t N, size_t... Is>
struct range_builder : public range_builder<MIN, N - 1, N - 1, Is...>
{
};
}
// Meta-function that returns a [MIN, MAX) index range
template<unsigned MIN, unsigned MAX>
using index_range = typename detail::range_builder<MIN, MAX>::type;
另请注意,Jonathan Wakely提出了一个有趣的提议来标准化类模板,这与我在这里所说的非常相似。int_seq
index_list