速度差异:使用*this在一个大类中分离仿函数VS operator()

Phi*_*hil 1 c++ performance operators this operator-keyword

我正在使用c ++ STL堆算法,我在它周围写了一个包装类,所以我可以做一些其他的东西.当我尝试使用下面的代码时,例如:

//! Min-heap wrapper class.
class FMMHeap{
public:
    FMMHeap(Vector &phi) : _phi(phi) {}
    bool operator()(unsigned p1, unsigned p2) {return fabs(_phi(p1)) > fabs(_phi(p2)); }
    inline void pop(){ pop_heap(_heap.begin(),_heap.end(),*this); _heap.pop_back(); }
    [...lots of other stuff...]
    vectorU32 _heap;
    Vector &_phi;
}
Run Code Online (Sandbox Code Playgroud)

它比我有一个像这样的单独的函数对象慢得多:

struct HeapSort{
public:
    HeapSort(Vector &phi) : _phi(phi) {}
    bool operator()(unsigned p1, unsigned p2) {return fabs(_phi(p1)) > fabs(_phi(p2)); }
private:
    Vector &_phi;
};

class FMMHeap{
public:
    FMMHeap(Vector &phi) : cmp(phi) {}
    inline void pop(){ pop_heap(_heap.begin(),_heap.end(),cmp); _heap.pop_back(); }
    [...lots of other stuff...]
    vectorU32 _heap;
    HeapSort cmp;
}
Run Code Online (Sandbox Code Playgroud)

我不确定为什么会这样.减速来自*这是因为班级有很多数据吗?这看起来很奇怪.或者它与如何使用函数对象有关?

Ale*_*eem 8

我不确定:但pop_heap最终可能会复制你传入的仿函数对象.你的副本FMMHeap会比简单的更复杂HeapSort