C++可以根据传入的函数指针,获取自己需要的参数类型,然后根据参数源中获取需要的参数,这里我用tuple作为演示,不过,只要可以根据序号,或者顺序方式等获取实参,都可以使用类似的方式实现:
先给出一个辅助函数:
1
2
3
4
5
6
7
8
9
10
11
12
|
/** 获取第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...>; }; |
下面给出实际的实现函数:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
|
#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; }; |
下面是测试用例:
1
2
3
4
5
6
7
8
9
10
11
12
13
|
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++根据传入的函数指针来解析需要的参数,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!
原文链接:https://www.cnblogs.com/albizzia/archive/2018/05/06/8997920.html