这类似于成员函数指针转换,从派生到基类,但不完全相同。 另外,我在这里发布了一个答案,尽管关于类似问题的多个帖子说这"是不可能的"。
我有一个类构造函数,它接受一个指针一个对象和该对象类的成员函数。 它将回调该对象。
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 )