繁体   English   中英

C 中内置 arguments 的函数数组

[英]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};

https://godbolt.org/z/ejMn4n

如果您制作数组staticauto ,包装器甚至可以是内联的。

您可以使用结构将它们捆绑在一起:

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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM