我有两节课TestA
and TestB
. TestA
延伸QObject
。我已经设置了一些Q_PROPERTY
就这样。
Q_PROPERTY(QString a_string READ getString WRITE setString)
Q_PROPERTY(int a_int READ getInt WRITE setInt)
当然,我创建了适当的 getter 和 setter。这个类效果很好。
在我的第二节课上,TestB
,我想创建一个Q_PROPERTY
这是一个TestA
,所以我这样做了testb.h
.
Q_PROPERTY(TestA testa READ getTestA)
public:
TestA *getTestA();
private:
TestA mTestA;
而这在testb.cpp
.
TestA *TestB::getTestA() {return &mTestA;}
当我尝试编译它时,我收到以下错误消息。
moc_testb.cpp: In member function 'virtual int TestB::qt_metacall(QMetaObject::Call, int, void**)':
moc_testb.cpp:75: error: no match for 'operator=' in '*(TestA*)_v = TestB::getTestA()'
../qttest/testa.h:7: note: candidates are: TestA& TestA::operator=(const TestA&)
有人可以告诉我需要做什么来解决这个问题吗?
我认为该错误与 READ 操作有关。它导致引用的 QT 函数期望 testa 是 TestA 类型的对象,该对象由函数 getTestA 返回。但是,getTestA 返回一个指向 TestA 类型的对象的指针。
我认为你可以通过将 getTestA 的原型更改为来解决该问题TestA getTestA();
并声明如下:TestA TestB::getTestA() {return mTestA;}
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)