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)
}
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;
}
5条答案
按热度按时间ikfrs5lh1#
绝对的
sg2wtvxw2#
假设你有一个函数:
所以指向它的指针是:
然后,你可以像这样使用它:
为了避免每次都指定完整的指针类型,你可以
typedef
它:然后像其他类型一样使用它:
我建议看看世界著名的C faqs。
ao218c7q3#
这是一个很好的例子:
l0oc07j24#
正如其他答案所说,你可以这样做,
但是,声明函数指针类型的参数有一种特殊情况:如果一个参数具有函数类型,它将被转换为指向函数类型的指针,就像数组被转换为参数列表中的指针一样,因此前者也可以写为
当然,这只适用于参数,因为在参数列表
int compar(const void *, const void *);
之外会声明一个函数。acruukt95#
检查
qsort()
函数的最后一个参数是函数指针。当你在你的程序中调用
qsort()
时,执行“进入库”,并通过使用该指针“返回到你自己的代码中”。