函数指针是存储函数入口地址的变量,用于回调机制;声明需严格匹配返回值和参数类型,如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*,不是函数指针。
作为参数传递实现回调
把函数指针当普通参数传入,就能在被调函数内部触发回调:
立即学习“C++免费学习笔记(深入)”;
动态WEB网站中的PHP和MySQL详细反映实际程序的需求,仔细地探讨外部数据的验证(例如信用卡卡号的格式)、用户登录以及如何使用模板建立网页的标准外观。动态WEB网站中的PHP和MySQL的内容不仅仅是这些。书中还提到如何串联JavaScript与PHP让用户操作时更快、更方便。还有正确处理用户输入错误的方法,让网站看起来更专业。另外还引入大量来自PEAR外挂函数库的强大功能,对常用的、强大的包
- 定义接受函数指针的函数,比如: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
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
sort(v.begin(), v.end(), compare_asc); // 传函数名,自动转函数指针
sort(v.begin(), v.end(), compare_desc);
这里 sort 第三个参数就是函数指针类型(或兼容的 callable),底层按需调用你提供的逻辑。
基本上就这些。函数指针不复杂但容易忽略括号和类型一致性,用 std::function 可以绕过多数限制,更安全也更常用。








