【发布时间】:2017-11-07 00:57:07
【问题描述】:
这类似于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 构造函数中失败。传递给超类的参数不是 kosher。那是: FunctionPoller( someClass, &SomeClass::poll )这行错误:
'QByteArray (SomeClass::)()' 中的参数 2 没有已知的转换 到 'PollerClientFetchFunc {aka QByteArray (QObject::)()}'
简而言之,在这种情况下,它似乎无法将SomeClass 转换为QObject,即使它是它的后继者。这里有什么问题?
【问题讨论】:
-
"简而言之,它似乎无法将 SomeClass 转换为 QObject.." 不,第一个参数没问题,错误是第二个。
-
等等,什么?如果是这样的话,这不知何故超出了我的想象。那么第二个论点是什么?
-
这是函数指针的问题,并转换了它的所有者类,不是吗?这就是我想说的。指向对象的指针很好。
-
是的。所有者类必须是您指定的基类。
标签: c++ polymorphism function-pointers member-function-pointers