模板化的 Q_OBJECT 基类

问题描述

我有几节课:

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 中,所以我有这些链接器错误