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 *));

ただし、関数ポインタ型の引数を宣言する特別な場合が1つあります。引数に関数型がある場合、配列がパラメータリストのポインタに変換されるのと同じように、関数型へのポインタに変換されます。次のように書くこともできます

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 に答える