您好,登錄后才能下訂單哦!
本文主要是針對QObject的拷貝構造函數和賦值運算符進行說明。先來看一下拷貝構造函數定義:拷貝構造函數,又稱復制構造函數,是一種特殊的構造函數,它由編譯器調用來完成一些基于同一類的其他對象的構建及初始化。其唯一的形參必須是引用,但并不限制為const,一般普遍的會加上const限制。此函數經常用在函數調用時用戶定義類型的值傳遞及返回。拷貝構造函數要調用基類的拷貝構造函數和成員函數。如果可以的話,它將用常量方式調用,另外,也可以用非常量方式調用。
還記得《[QT入門篇]1 QT中的對象模型》中的說明么?QObject被當做標識對待,不是值,所以不能復制,這和拷貝構造函數的定義是沖突的,所以OQbject沒有拷貝構造函數,或者說QObject的拷貝構造函數不能調用。來,看看代碼,加深理解。
拷貝構造函數的一般形式為:T(const T& t)
代碼1:
#include <QCoreApplication> #include <QObject> int main(int argc, char *argv[]) { QCoreApplication a(argc, argv); QObject x; x.setObjectName("x"); QObject y(x); return a.exec(); }
編譯時,提示“QObject y(x);”有錯誤:
=========================================
E:\Qt\Qt5.6.0\5.6\mingw49_32\include\QtCore\qobject.h:461: error: 'QObject::QObject(const QObject&)' is private
Q_DISABLE_COPY(QObject)
^
========================================
從錯誤提示中,我們能夠看出QObject::QObject(const QObject&)是私有的,不能調用。跟蹤到OQbject.h中能看到這樣的定義:
……
private:
Q_DISABLE_COPY(QObject)
……
毫無疑問,QT把QObject的拷貝構造函數干掉了。同理,QObject的“=”運算符也是一樣被干掉了,看下面的代碼:
代碼2:
#include <QCoreApplication> #include <QObject> int main(int argc, char *argv[]) { QCoreApplication a(argc, argv); QObject x; x.setObjectName("x"); QObject y; y = x; return a.exec(); }
編譯時,“y=x”報錯:
========================
E:\Qt\Qt5.6.0\5.6\mingw49_ 'QObject& QObject::operator=(const QObject&)' is private
Class &operator=(const Class &) Q_DECL_EQ_DELETE;
======================
“=”運算符也被置為私有,在qglobal.h中有這樣的定義:
……
#define Q_DISABLE_COPY(Class) \
Class(const Class &) Q_DECL_EQ_DELETE;\
Class &operator=(const Class &) Q_DECL_EQ_DELETE;
……
總結一下:QObject既沒有拷貝構造函數也沒有賦值運算符。QT的設計即是如此。實際上,這兩者都被聲明了,只不過它們使用了Q_DISABLE_COPY宏并在類的私有段聲明的。QObject所有的直接子類和間接子類都沒有拷貝構造函數和賦值運算符。
這樣做的結果是,開發者在某些場景下需要使用OQbject作為“值”時,必須使用QObject指針傳遞,而不能使用值傳遞。
QT為了防止開發人員出錯也是煞費苦心啊~
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。