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++根據傳入的函數指針來解析需要的參數,希望對大家有所幫助,如果大家有任何疑問歡迎給我留言,小編會及時回復大家的!
新聞熱點
疑難解答
圖片精選