C 函数指针作为参数
是否可以将函数指针作为参数传递给C中的函数 如果是这样,我将如何声明和定义一个以函数指针为参数的函数?当然C 函数指针作为参数,c,function-pointers,argument-passing,C,Function Pointers,Argument Passing,是否可以将函数指针作为参数传递给C中的函数 如果是这样,我将如何声明和定义一个以函数指针为参数的函数?当然 void f(void (*a)()) { a(); } void test() { printf("hello world\n"); } int main() { f(&test); return 0; } 假设你有功能 int func(int a, float b); 所以指向它的指针将是 int (*func_pointer)(i
void f(void (*a)()) {
a();
}
void test() {
printf("hello world\n");
}
int main() {
f(&test);
return 0;
}
假设你有功能
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);
为了避免每次需要时都指定完整指针类型,可以键入def
而不是像其他类型一样使用
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)
}
我建议去看看世界著名的餐馆。看看qsort
函数的最后一个参数是函数指针。当您在自己的程序中调用qsort时,执行将进入库并通过使用该指针返回到您自己的代码中。这是一个很好的示例:
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;
}
正如其他答案所说,你可以像
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 comparconst void*,const void*;将声明一个函数。两者都将起作用。符号是可选的。调用函数指针时取消对指针的引用也是如此。是的,不需要更改任何内容。此外,即使参数声明中的指针语法也是可选的。上面的f可以被声明为void fvoid a。使用函数指针类型的typedef可以使代码eaiser读取。有没有一种方法可以使指针指向一个函数,该函数具有一个预定义的输入值?假设我们有void f float*data,float funParam。我们能不能有一个指向函数的指针,该函数的某个值为funParam?@Royi no。另请看举世闻名的+1,了解下面提到的利用隐式指针转换提高可读性的技巧。
The output is : '22, 5'
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 *));