答案是使用函数指针、std::function、lambda、仿函数和成员函数包装实现回调。函数指针适用于普通函数;std::function结合lambda更灵活;仿函数支持状态管理;成员函数需通过bind或lambda包装。C++11后推荐std::function与lambda组合,安全且通用。

在C++中实现回调函数有多种方式,核心思想是将函数作为参数传递给其他函数,在特定时机被“回调”。常见的实现方法包括函数指针、std::function、lambda表达式、仿函数(functor)以及成员函数回调。下面逐一介绍这些方法。
1. 函数指针实现回调
最基础的方式是使用函数指拉。适用于普通函数或静态函数的回调。
示例:
#includeusing namespace std; // 回调函数类型定义 typedef void (*Callback)(int); // 被调用方,接受回调函数作为参数 void doSomething(Callback cb) { cout << "执行一些操作..." << endl; if (cb) { cb(42); // 触发回调 } } // 实际的回调函数 void myCallback(int value) { cout << "回调被触发,值为: " << value << endl; } int main() { doSomething(myCallback); // 传入函数指针 return 0; }
2. 使用 std::function 和 lambda
更现代、灵活的方式是使用 std::function,它可以封装普通函数、lambda、绑定表达式等。
示例:
#include#include using namespace std; void doWork(const std::function & callback) { cout << "工作中..." << endl; callback(100); } int main() { // 使用 lambda 作为回调 doWork([](int x) { cout << "Lambda 回调: " << x << endl; }); // 也可以传普通函数 doWork(myCallback); return 0; }
3. 仿函数(Functor)实现
通过重载函数调用运算符的类对象实现回调,适合需要携带状态的场景。
立即学习“C++免费学习笔记(深入)”;
示例:
struct MyFunctor {
void operator()(int value) const {
cout << "Functor 回调: " << value << endl;
}
};
// 使用方式
doWork(MyFunctor{});
4. 成员函数作为回调
成员函数有隐含的 this 指针,不能直接用函数指针传递。可以配合 std::bind 或 lambda 包装。
示例:
class Handler {
public:
void onEvent(int value) {
cout << "成员函数回调: " << value << endl;
}
};
int main() {
Handler h;
// 使用 bind
auto bound = std::bind(&Handler::onEvent, &h, std::placeholders::_1);
doWork(bound);
// 或使用 lambda 包装
doWork([&h](int x) { h.onEvent(x); });
return 0;
}
基本上就这些。选择哪种方式取决于你的需求:简单场景用函数指针,复杂或需要状态时推荐 std::function 配合 lambda。C++11 以后这种方式更安全、通用。











