这类似于Member function pointer cast, from Derived to Base class但不完全相同。另外,我在这里发了一个答案,尽管有类似问题的多个帖子说它“不可能”。
我有一个类构造函数,它将指针作为对象和该对象类的成员函数。它将回调该对象。
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没有已知的转换 'PollerClientFetchFunc {aka QByteArray(QObject :: )()}'
简而言之,它似乎无法在此上下文中将SomeClass
转换为QObject
,即使它是它的后果。这有什么不对?
答案 0 :(得分:0)
我明白了。有时候只需要发一个问题就能最终得到答案!解决方案是只显式地转换函数指针。
: FunctionPoller( someClass, (PollerClientFetchFunc) &SomeClass::poll )