0

问候我正在尝试在特殊对象上使用 std::sort 算法。我有一个要排序的列表和一个二进制函数,它可以给我一个比较:

B.cpp 中有趣的部分

    void B::FindClosest(vector<A*> list)
        {     
          bool (B::*ptr)(A*,A*) = &B::Closer;     
          sort(list.begin(),list.end(),(this->*ptr));
          // some use of this sorted list   
        }

    bool B::Closer(A* lhs ,A* rhs)
    {
       if(Distance(this,lhs)<Distance(this,rhs))
       {
          return true;
       }
       else
       {
          return false;
       }
     }

和 Bh:

  class B : public A
   public:
   void FindClosest(vector<A*>);
   bool Closer(A*,A*);

这看起来很简单,但我不知道为什么它不起作用。在我看来,我在指向成员函数的指针上做错了,但不知道是什么。

这是错误消息:

agglomerate.cpp:32: error: invalid use of non-static member function

我已经尝试过其他一些方法来让事情正常工作,但没有。

我不限于指向成员函数的指针,如果您有一种简单/不同的方法来做到这一点,欢迎您。

非常感谢,

阿兹瑞拉

4

2 回答 2

3

你不能使用这样的东西,你应该使用std::bindor boost::bindorlambda在这种情况下,因为sort第三个参数应该是可调用对象,它接收两个类型的对象T

有了std::bind它就会

using namespace std::placeholders;
sort(list.begin(), list.end(), std::bind(ptr, this, _1, _2));
于 2013-04-30T11:12:05.463 回答
0

这一行:

bool (B::*ptr)(A*,A*) = &B::Closer;

获取指向成员函数 B 的点。要调用此函数,您需要一个类实例来调用它(成员函数需要知道它可以访问的类数据的具体实例等)。例如

(this->*ptr)(lhs, rhs)

调用 this 的成员函数。如果你做了

B anotherB;
bool (B::*ptr)(A*,A*) = &B::Closer;
(anotherB.*ptr)(lhs, rhs)

这将调用 B::Closer 函数,但这次使用 anotherB 而不是 this(假设这不是“anotherB”)

我不确定是什么...

 (this->*ptr)

...评估为?,但这是问题所在

我认为问题在于你不能给 sort() 类实例和成员函数指针......你只能给它成员函数指针,所以它没有可以调用这个函数的类实例。

正如 ForEveR 建议的那样,您可以使用 std::bind 以便您可以从具有四个参数的函数转换:hls、rhs、类实例、成员指针。将一个绑定到“this”,将一个绑定到所需的成员函数,这样结果就是一个只需要 lhs 和 rhs 的函数。

于 2013-04-30T11:29:24.547 回答