2

我有两个班,TestATestBTestA延伸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是 a 的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&)

有人能告诉我我需要做什么来解决这个问题吗?

4

1 回答 1

2

我认为该错误与 READ 操作有关。它导致引用的 QT 函数期望 testa 是 TestA 类型的对象,该对象由函数 getTestA 返回。但是,getTestA 返回一个指向 TestA 类型对象的指针。

我认为您可以通过将 getTestA 的原型更改为 TestA getTestA();

并声明如下: TestA TestB::getTestA() {return mTestA;}

于 2012-06-24T02:21:27.893 回答