//function wapper
template<class F,typename...Args>
class FuncWrapper
{
private:
//F return type
using return_type = typename std::result_of<F(Args...)>::type;
template<int ...S> struct IndexSeq {};
template<int N, int ...S> struct makeSeq : makeSeq<N - 1, N - 1, S...> {};
template<int ...S> struct makeSeq<0, S...> : IndexSeq<S...> {};
public:
FuncWrapper(F &&func,Args&&...args):
f(std::move(std::function<return_type(Args...)>(std::forward<F>(func)))),
para(std::make_tuple<Args...>(std::forward<Args>(args)...))
{}
~FuncWrapper() = default;
template <int... INDEX>
return_type delay_action(makeSeq<INDEX...>)
{
return f(std::get<INDEX>(para)...);
}
//
return_type operator()()
{
return delay_action(makeSeq<sizeof...(Args)>{});
}
private:
//function
std::function<return_type(Args...)> f;
//parameter in the tuple
std::tuple<Args...> para;
};
template<class F,typename ...Args>
FuncWrapper<F,Args...> make_function_wapper(F &&f, Args&&...args)
{
return FuncWrapper<F, Args...>(std::forward<F>(f), std::forward<Args>(args)...);
}
這裏是一個問題:我想爲包裝函數創建一個模板類,併爲參數存儲使用元組,但它似乎不能很好地工作,我無法找到原因。 所以我需要一些幫助,誰可以解釋它。 thx爲您的幫助!如何在C++ 11中解封裝函數參數的元組?
是否有理由不能使用C++ 14的['index_sequence'](http://en.cppreference.com/w/cpp/utility/integer_sequence)而不是您自己的'IndexSeq'? –
@JonathanWakely:可能是因爲它被標記爲C++ 11(並在標題中重複)。 – Jarod42
@ Jarod42,但仍然可以在C++ 11中使用'integer_sequence',例如[integer_seq.h](https://gitlab.com/redistd/integer_seq/blob/master/integer_seq.h)。這將是「前向兼容」,而不是重新發明輪子,用不同的拼寫。 –