0

这应该是一个简单的问题,但我可能无法正确表达它,或者我可能因为缺乏经验而试图挑战 C 语言的原则。

我想要做的就是,给定一个指向函数的指针,将它包装在另一个函数中,该函数将指向函数的指针作为参数,并制作后者的指针。代码更好:

void do_nothing_1() {}
void do_nothing_2() {}

void wrapper(void(*f)()) { f(); }

int main() {

    // the following will call the function
    // but i just want a pointer of whats being called
    funcion_pointer_1 = wrapper(do_nothing_1);
    funcion_pointer_2 = wrapper(do_nothing_2);

    return 0;
}

如果这个问题没有任何意义,我事先道歉,请帮助我澄清它,而不是简单地否决它。

编辑:鉴于由于要求的模糊性而获得所需结果的明显困难,我将对我正在寻找的内容进行更具体的说明。

在结构内部,我有一个指向函数的指针:

struct my_struct {
    int (* run)(void);
}

我想做的是修改那个函数,这就是我使用包装器的原因。因此,例如,如果 foo 返回 void,则将其更改为 int。另外,在执行 foo 之前运行一些代码:

int wrapper(void (*foo)()) {

    // exec some stuff here

    foo();

    return 0;
}

最终,我想要的是当我从我的结构中执行与 *run 指针对应的函数时,在执行 run() 之前执行一些东西并更改返回类型。

4

1 回答 1

3

在努力使用正确的语法时,使用 typedef 使事情更清晰会很有帮助。不仅是为你自己编写代码,还为任何需要维护它的人,或者只是想弄清楚它在做什么。

您需要一个函数指针,该函数指针指向一个将另一个函数指针作为参数的函数。从参数开始,一个没有参数且没有返回值的函数:

typedef void (*void_handler_t)( void);

现在是包装函数指针,它接受一个函数指针参数并且没有返回值:

typedef void (*wrapper_handler_t)( void_handler void_fn);

和代码:

void foo( void) {}
void wrapper( void_handler_t wrapped_fn)
{
    wrapped_fn();
}

int main( int argc, char *argv[])
{
    wrapper_handler_t function_pointer;

    function_pointer = &wrapper;
    function_pointer( &foo);

    return 0;
}
于 2012-06-09T05:41:38.447 回答