C++可以根據傳入的函數指針,獲取自己需要的參數類型,然后根據參數源中獲取需要的參數,這里我用tuple作為演示,不過,只要可以根據序號,或者順序方式等獲取實參,都可以使用類似的方式實現:
先給出一個輔助函數:
/** 獲取第N個類型*/template <typename... Cases>struct select{};template <typename T, typename... Cases>struct select<T, Cases...> : public select<Cases...>{ using ThisType = T; using Base = select<Cases...>;};下面給出實際的實現函數:
#include <functional>#include "vs-help.h"class TupleFunc{public: TupleFunc() { } // 函數的實際構造過程 template <typename Ret, typename... Args, typename ParamsSource> void makeFuncAndParams(Ret(*func)(Args...), ParamsSource& paramSource) { makeFuncAndParamsImpl<0>(func, select<Args...>(), paramSource); } // 實際調用 void invoke() { m_func(); }private: // 實際調用初始化 template <size_t idx, typename Func, typename Select, typename ParamsSource, typename... Params> void makeFuncAndParamsImpl(Func&& func, Select, ParamsSource& paramSource, Params&&...args) { typename Select::ThisType param = std::get<idx>(paramSource); makeFuncAndParamsImpl<idx + 1>(func, Select::Base(), paramSource, std::forward<Params>(args)..., std::move(param)); } // 結束調用 template <size_t idx, typename Func, typename ParamSource, typename... Params> void makeFuncAndParamsImpl(Func&& func, select<>, ParamSource& paramSource, Params&&... args) { m_func = [func, args...]() { func(args...); }; }private: std::function<void()> m_func;};下面是測試用例:
void print(int x, std::string y){ std::cout << "x: " << x << std::endl; std::cout << "y: " << y << std::endl;}int main(){ std::tuple<int, std::string, std::string> p = { 12, "job", "China" }; TupleFunc func; func.makeFuncAndParams(&print, p); func.invoke(); return 0;}通過使用lambda表達式,我們可以很方便的構建一個我們調用時需要的函數,而模板的存在,可以使我們在構建一個lambda表達式的時候,可以動態化,使某些情況下,更加靈活的構建各類處理函數map等。上面只是簡單的演示,具體場景下,需要進行一定的修改。
總結
以上所述是小編給大家介紹的C++根據傳入的函數指針來解析需要的參數,希望對大家有所幫助,如果大家有任何疑問歡迎給我留言,小編會及時回復大家的!
新聞熱點
疑難解答
圖片精選