C++ ptr_fun与mem_fun的区别_C++函数适配器的历史与替代方案

ptr_fun用于包装普通函数指针,mem_fun用于包装成员函数指针,二者均为早期STL适配器;2. 因语法繁琐且功能受限,自C++11起被lambda、std::function和std::bind取代;3. C++17中正式移除,现代代码应使用lambda或bind替代。

c++ ptr_fun与mem_fun的区别_c++函数适配器的历史与替代方案

在C++标准库中,ptr_funmem_fun 是早期用于适配函数指针和成员函数指针的函数适配器,主要用于配合STL算法使用。随着语言的发展,它们逐渐被更现代、更灵活的机制取代。理解它们的区别以及为何被淘汰,有助于掌握C++函数对象演进的历史脉络。

ptr_fun:普通函数指针的包装器

ptr_fun 用于将普通函数指针转换为函数对象(functor),以便能被STL算法接受。某些老式STL实现要求函数对象具有特定的类型特征(如result_type),而裸函数指针不具备这些typedef,因此需要包装。

示例:

假设有函数:
bool is_even(int n) { return n % 2 == 0; }
在旧式代码中,要传递给std::not1等适配器时需包装:
std::ptr_fun(is_even)
这会生成一个带类型定义的函数对象,支持绑定与取反操作。

mem_fun:成员函数的适配器

mem_fun 专门用于包装类的成员函数指针,使其能通过对象指针调用。常用于std::for_eachstd::transform等算法中对容器中对象指针调用成员函数。

示例:

对于类:
class Task { public: void run(); };
容器为std::vector时,可使用:
std::for_each(tasks.begin(), tasks.end(), std::mem_fun(&Task::run));
它会自动解指针并调用成员函数。

C++还提供mem_fun_ref用于对象引用的场景,适用于存储实际对象而非指针的容器。

立即学习“C++免费学习笔记(深入)”;

历史局限与替代方案

上述适配器在C++98/03时代是必要的,但存在明显缺陷:

语法繁琐,需显式指定模板参数或依赖重载解析不支持任意可调用对象(如仿函数、lambda)对参数数量敏感,有mem_funmem_fun1等变体

从C++11开始,以下现代机制全面替代了它们:

Lambda表达式:最直接的方式,可捕获上下文并内联定义逻辑std::function:统一封装任意可调用对象std::bind:灵活绑定函数与参数,包括成员函数自动类型推导(auto):简化函数对象的使用

现代替代示例:

用lambda调用成员函数:
std::for_each(tasks.begin(), tasks.end(), [](Task* t) { t->run(); });
或使用bind:
std::for_each(tasks.begin(), tasks.end(), std::bind(&Task::run, std::placeholders::_1));

在C++17中,ptr_funmem_fun 已被正式移除。编译器虽可能仍支持出于兼容性考虑,但不应再使用。

基本上就这些。老式适配器是特定历史阶段的产物,理解它们有助于阅读旧代码,但在新项目中应优先使用lambda和std::bind。

以上就是C++ ptr_fun与mem_fun的区别_C++函数适配器的历史与替代方案的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1486163.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月19日 09:34:22
下一篇 2025年12月19日 09:34:37

相关推荐

发表回复

登录后才能评论
关注微信