[英]Array of functions with built in arguments in C
假设我有这两个函数和这两个函数的数组的定义:
int flag;
int add(int a, int b){
return a+b;
}
int multiply(int a, int b){
return a*b;
}
typedef int(*f)(int, int);
f func_array[2] = {&add, &multiply};
现在,我的代码中有一个特定位置,我想根据我的标志 state 调用这两个函数,每次都使用相同的 arguments 。
例如:
int var;
if(flag == 0)
{
var = func_array[flag](1,1);
}
else{
var = func_array[flag](2,2);
}
有没有办法在数组本身内部定义它? Somwhow 像这样定义数组并调用 function:
f func_array[2] = {&add(1,1), &multiply(2,2)};
int var = func_array[flag]();
这是一种有效的方式吗? 有没有更优雅的方法来做到这一点?
您可以为每个参数定义一组 arrays:
#define ARR_SIZE 2
typedef int(*f)(int, int);
f func_array[ARR_SIZE] = {&add, &multiply};
int param1_array[ARR_SIZE] = { 1, 2};
int param2_array[ARR_SIZE] = { 1, 2};
电话会变成
if(flag < ARR_SIZE)
{
int var = func_array[flag](param1_array[flag], param2_array[flag]);
}
我刚刚添加了对数组大小的检查。
用宏
#define flag_call(flag) \
func_array[flag](param1_array[flag], param2_array[flag])
你可以更简化它
if(flag < ARR_SIZE)
{
flag_call(flag);
}
不知道重点是什么,但你可以这样做:
int add11(void){ return add(1,1); }
int multiply22(void){ return multiply(2,2); }
/*skipped the new typedef*/
int (*func_array2[2])(void) = {&add11,&multiply22};
如果您制作数组static
或auto
,包装器甚至可以是内联的。
您可以使用结构将它们捆绑在一起:
typedef int(*f)(int, int);
struct func_and_args {
f func;
int a;
int b;
}
...
struct func_and_args arr[] = {{&add,1,1},{&multiply,2,2}};
int var = arr[flag].func(arr[flag].a,arr[flag].b);
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.