问题描述
我有几节课:
A.h
class Abase_obj : public QObject
{
Q_OBJECT
Q_PROPERTY(QAction* playAction READ playAction CONSTANT)
public:
Abase_obj(QObject* parent = nullptr) : QObject(parent) {}
virtual QAction* playAction() = 0;
signals:
void someSignal()
slots:
virtual void baseSlot() = 0;
};
template <class T>
class Abase : public Abase_obj
{
public:
Abase(QObject* parent = nullptr) : Abase_obj(parent) {...}
void baseSlot() override;
QAction* playAction() override;
protected:
QWeakPointer<T> m_currentItem;
};
template <class T>
Abase<T>::baseSlot() {
auto item = m_currentItem.lock();
item->someMethodofTemplateClass(); // here is the error
}
B_inh.h
#include "A.h"
class MediaItem;
class B_inh : public Abase<MediaItem>
{
Q_OBJECT
Q_PROPERTY(MediaItem* getItem READ getItem)
public:
// constructor
MediaItem* getItem();
public slot:
// some new slot
}
所以我使用 Abase_obj 因为我不能在模板类中输入 Q_OBJECT 宏并在那里定义一些插槽和信号。我知道我可以定义没有模板化参数的插槽。但是我直接在这个插槽中使用了模板方法。但是由于 Abase_obj 元对象不知道这个类,我得到错误:error: C2039: 'someMethodofTemplateClass': is not a member of 'QSharedPointer' 和 error: C2027: use of未定义类型“MediaItem”。所以我有两个问题:第一个是我应该如何实现这个插槽才能让它工作,第二个问题在上面的评论中。
更新:如果我制作 #include "MediaItem.h" 而不是向前声明它,我会收到错误:
LNK2001: unresolved external symbol "public: static struct QMetaObject const Abase_obj::staticMetaObject" : in file B_inh.cpp.obj
LNK2001: unresolved external symbol "public: virtual void * __cdecl Abase_obj::qt_Metacast(char const *)" : in file B_inh.cpp.obj
LNK2001: unresolved external symbol "public: virtual struct QMetaObject const * __cdecl Abase_obj::MetaObject(void)const " : in file B_inh.cpp.obj
如果我从 Abase_obj 中删除 Q_OBJECT 宏和所有 Q_PROPERTIes 并将它们添加到 B_inh 类,一切都在编译和工作,但我不想每次都在所有派生类中实现这些属性
解决方法
代码正确。错误在于我的qbs 依赖项。文件 A.h 还没有被编译,也没有被正确地包含到 B_inh.h 中,所以我有这些链接器错误