[QT入門篇]3 QObject的拷貝構造函數與賦值運算符

本文主要是針對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爲了防止開發人員出錯也是煞費苦心啊~


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章