bja*_*fly 3 c++ templates variadic-templates c++11
如何访问参数包中的各个项目?
鉴于以下内容:
template<typename T>
struct X {};
template<class R, class... Args>
struct X<R (Args...)>
{
// how can I create a typedef for the first parameter
// basically I want to do something like if arg1 exists typedef it
// pseduo code below
if (Args[0])
typedef typename Args[0] Parameter1
}
Run Code Online (Sandbox Code Playgroud)
否则我可能不得不做这样的事情,但希望保持通用
template<class R, class... Args>
struct X<R (Arg1, Args...)>
{
}
Run Code Online (Sandbox Code Playgroud)
通过帮助程序获取param包中的第一项非常简单:
template <typename T, typename... Ts>
using first_type = T;
Run Code Online (Sandbox Code Playgroud)
但是,如果您的参数包为空,这当然无法编译.你的背包是空的时候你会期待什么样的行为?你不想让typedef存在吗?在这种情况下,只需将您的struct X部分特化为空参数包.
你可以使用std::tuple_element:
template<typename... Args>
struct arg
{
template<int N>
using type = typename std::tuple_element<N, std::tuple<Args...>>::type;
};
template<typename R, typename... Args>
struct X<R (Args...)>
{
using first = typename arg<Args...>::template type<0>;
};
Run Code Online (Sandbox Code Playgroud)
这将允许您通过编译时索引访问任意类型.您还可以static_assert在编译时断言参数包至少有一个元素.
template<typename... Args>
struct has_first_arg : std::true_type { };
template<>
struct has_first_arg<> : std::false_type { };
template<typename R, typename... Args>
struct X<R (Args...)>
{
static_assert(has_first_arg<Args...>::value,
"Parameter pack must have at least one element");
};
Run Code Online (Sandbox Code Playgroud)