45

是否可以将函数指针作为参数传递给 C 中的函数?

如果是这样,我将如何声明和定义一个将函数指针作为参数的函数?

4

5 回答 5

80

确实。

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

void test() {
    printf("hello world\n");
}

int main() {
     f(&test);
     return 0;
}
于 2009-11-24T12:38:46.587 回答
31

假设你有功能

int func(int a, float b);

所以指向它的指针将是

int (*func_pointer)(int, float);

所以你可以像这样使用它

  func_pointer = func;
  (*func_pointer)(1, 1.0);

  /*below also works*/
  func_pointer(1, 1.0);

为了避免每次需要时都指定完整的指针类型,你可以使用typedef

typedef int (*FUNC_PTR)(int, float);

而不是像任何其他类型一样使用

void executor(FUNC_PTR func)
{ 
   func(1, 1.0);
}

int silly_func(int a, float b)
{ 
  //do some stuff
}

main()
{
  FUNC_PTR ptr;
  ptr = silly_func;
  executor(ptr); 
  /* this should also wotk */
  executor(silly_func)
}

我建议查看世界著名的C 常见问题解答

于 2009-11-24T12:43:07.500 回答
14

这是一个很好的例子:

int sum(int a, int b)
{
   return a + b;
}

int mul(int a, int b)
{
   return a * b;
}

int div(int a, int b)
{
   return a / b;
}

int mathOp(int (*OpType)(int, int), int a, int b)
{
   return OpType(a, b);
}

int main()
{

   printf("%i,%i", mathOp(sum, 10, 12), mathOp(div, 10, 2));
   return 0;
}
The output is : '22, 5'
于 2015-11-12T20:44:55.760 回答
3

正如其他答案所说,你可以这样做

void qsort(void *base, size_t nmemb, size_t size,
           int (*compar)(const void *, const void *));

但是,声明函数指针类型的参数有一种特殊情况:如果参数具有函数类型,它将被转换为指向函数类型的指针,就像数组被转换为参数列表中的指针一样,所以前者也可以写成

void qsort(void *base, size_t nmemb, size_t size,
           int compar(const void *, const void *));

当然,这仅适用于参数,因为在参数列表之外int compar(const void *, const void *);会声明一个函数。

于 2019-03-09T07:21:31.303 回答
2

查看qsort()

void qsort(void *base, size_t nmemb, size_t size,
           int (*compar)(const void *, const void *));

函数的最后一个参数是函数指针。当您调用您qsort()的程序时,执行“进入库”并通过使用该指针“退回到您自己的代码”。

于 2009-11-24T13:04:01.933 回答