我有两个班级,TestA
和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&)
有人可以告诉我我需要做些什么来解决这个问题吗?
答案 0 :(得分:1)
我认为该错误与READ操作有关。它导致引用的QT函数期望testa是TestA类型的对象,它由函数getTestA返回。但是,getTestA会返回指向TestA类型的对象的指针。
我认为您可以通过将getTestA的原型更改为来解决此问题
TestA getTestA();
并声明如下:
TestA TestB::getTestA() {return mTestA;}