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++根據傳入的函數指針來解析需要的參數,希望對大家有所幫助,如果大家有任何疑問歡迎給我留言,小編會及時回復大家的!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。