17370845950

C++中的函数指针如何使用?(回调函数示例)
函数指针是存储函数入口地址的变量,用于回调机制;声明需严格匹配返回值和参数类型,如int (*pf)(int, double)=func;传参时可作为普通参数实现回调调用。

C++中函数指针本质是存储函数入口地址的变量,常用于实现回调机制——即把一个函数作为参数传给另一个函数,在合适时机被调用。核心在于类型匹配和语法正确。

声明与初始化函数指针

函数指针类型必须和目标函数的返回值、参数列表完全一致。例如:

int func(int a, double b) { return a + (int)b; }
对应的函数指针声明为:int (*pf)(int, double) = func;int (*pf)(int, double) = &func;(取地址符可省略)。

常见错误:漏写括号,写成 int *pf(int, double) —— 这其实是函数声明,返回 int*,不是函数指针。

作为参数传递实现回调

把函数指针当普通参数传入,就能在被调函数内部触发回调:

  • 定义接受函数指针的函数,比如:void process_data(int x, double y, int (*callback)(int, double)) { int result = callback(x, y); cout
  • 调用时直接传函数名:process_data(5, 3.14, func);
  • 也可以传 lambda(需转成函数指针,但仅限无捕获 lambda):process_data(5, 3.14, [](int a, double b) { return a + (int)b; });

结合 std::function 更灵活(现代 C++ 推荐)

原生函数指针不支持绑定、lambda 捕获或成员函数。这时用 #include 中的 std::function 更通用:

  • 声明:std::function f = func;
  • 支持带捕获的 lambda:int base = 10; f = [base](int a, double b) { return a + base + (int)b; };
  • 也能包装成员函数(需配合对象或 std::bind)

实际回调场景示例:排序比较器

比如自定义 vector 排序规则:

bool compare_asc(int a, int b) { return a bool compare_desc(int a, int b) { return a > b; }
vector v = {3, 1, 4};
sort(v.begin(), v.end(), compare_asc); // 传函数名,自动转函数指针
sort(v.begin(), v.end(), compare_desc);

这里 sort 第三个参数就是函数指针类型(或兼容的 callable),底层按需调用你提供的逻辑。

基本上就这些。函数指针不复杂但容易忽略括号和类型一致性,用 std::function 可以绕过多数限制,更安全也更常用。