知乎:https://www.zhihu.com/people/monkey.d.luffy Android高级开发交流群2: 752871516
全部博文(315)
分类: C/C++
2013-05-05 15:37:30
调用STL算法并以某个类的成员函数为参数时,要用mem_fun或者mem_fun_ref,但是为什么我在书上看到,一个类中重载了 () , 然后在main函数里用for_each算法直接调用之,而不用mem_fun,为什么?难道调用重载的()就不用这个适配器吗?
一个类重载了(),它事实上就是一个仿函数(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源码剖析》提问者评价
原来如此,真是太谢谢你了