我要投搞

标签云

收藏小站

爱尚经典语录、名言、句子、散文、日志、唯美图片

当前位置:六合公式 > 仿函数 >

关于c++STL中使用mem_fun的问题

归档日期:05-20       文本归类:仿函数      文章编辑:爱尚语录

  调用STL算法并以某个类的成员函数为参数时,要用mem_fun或者mem_fun_ref,但是为什么我在书上看到,一个类中重载了(),然后在main函数里用for_each算法直接调用之,而不用mem_fun,为什...

  调用STL算法并以某个类的成员函数为参数时,要用mem_fun或者mem_fun_ref,但是为什么我在书上看到,一个类中重载了 () , 然后在main函数里用for_each算法直接调用之,而不用mem_fun,为什么?难道调用重载的()就不用这个适配器吗?

  可选中1个或多个下面的关键词,搜索相关资料。也可直接点“搜索资料”搜索整个问题。

  展开全部一个类重载了(),它事实上就是一个仿函数(functor)了。这其实是一个C++语法上的trick,因为C++的泛型是基于代码层面的,所以虽然调用函数和调用一个类的operator ()在本质上是不同的,但是在语法上的写法是一致的,因此就可以破例调用。

  STL的标准算法是不支持传入一个“成员函数指针”的(因为当没有实例化的对象的时候,成员函数根本不知道this是谁),但是支持“普通函数指针”或“仿函数”,而mem_fun、mem_fun_ref的作用就是将一个成员函数指针包装成一个仿函数。

  你说for_each的问题,关键是,它传入的是一个对象,而不是一个函数指针。for_each是允许一个对象作为仿函数被传入的(只要它重载了operator() ),但是for_each不允许你传入一个成员函数指针。你如果把一个类的成员函数作为参数,当然会出现问题。

  operator()和普通的成员函数并没有什么本质的不同,其实如果你显式的把一个仿函数的operator()传入for_each,也会报错的。但关键是人家传入的不是一个operator(),而是整个对象。

  这块涉及到的泛型编程知识,深究起来会有点深(特别是mem_fun的实现,非常tricky),想看的话建议去翻翻《C++标准程序库》和《STL源码剖析》

  mem_fun或者mem_fun_ref其实就是把一个成员函数变为一个函数对象而已,其内部相当于新建了一个你看不到的隐藏的类,然后重载(),再调用你的这个成员函数

本文链接:http://renfriends.com/fanghanshu/412.html