C++成员函数指针编译错误



这类似于成员函数指针转换,从派生到基类,但不完全相同。 另外,我在这里发布了一个答案,尽管关于类似问题的多个帖子说这"是不可能的"。

我有一个类构造函数,它接受一个指针一个对象和该对象类的成员函数。 它将回调该对象。

typedef QByteArray(QObject::*PollerClientFetchFunc)(void);
class FunctionPoller
{
public:
FunctionPoller( QObject *client,
PollerClientFetchFunc clientFunc ){} 
};

我还有另一个类,其中将定义功能代码:

class SomeClass : public QObject
{
Q_OBJECT
public:
SomeClass(){}   
QByteArray poll();
};

我有一个来自执行回调的派生类:

class MyPoller : public FunctionPoller
{
public:
MyPoller( SomeClass *someClass );
~MyPoller();
SomeClass *someClass_;
};
MyPoller::MyPoller( SomeClass *someClass )
: FunctionPoller( someClass, &SomeClass::poll )
, someClass_( someClass )
{}

此代码在 MyPoller 构造函数中失败。传递给超类的参数不是犹太洁食。这是: FunctionPoller( someClass, &SomeClass::poll )这是错误的行:

没有来自"QByteArray (SomeClass::)()"的参数 2 的已知转换 to 'PollerClientFetchFunc {aka QByteArray (QObject::)()}'

简而言之,在这种情况下,它似乎无法将SomeClass转换为QObject,即使它是它的死者。 这是怎么回事?

我明白了。 有时只需要发布一个问题就可以最终得出答案! 解决方案是显式强制转换函数指针。

: FunctionPoller( someClass, (PollerClientFetchFunc) &SomeClass::poll )

最新更新