從 Qt 的 delete 說開來

2021-07-28 08:19:35 字數 1640 閱讀 2110

從 qt 的 delete 說開來

在c++中學習過程中,我們都知道:

qt作為c++的庫,顯然是不會違背c++的前述原則的。可是:

注:本文暫不涉及智慧型指標(smart pointer)相關的東西,你可以考慮 qt 智慧型指標學習 一文

在qt中,以下情況下你new出的物件你可以不用親自去delete (但你應該清楚delete在何處被qt呼叫的,怎麼被呼叫的):

除此之外,有些類的物件可以接收設定一些特別的標記,比如:

在qt中,每個 qobject 內部都有乙個list,用來儲存所有的 children,還有乙個指標,儲存自己的parent。當它自己析構時,它會將自己從parent的列表中刪除,並且析構掉所有的children。

q_invokable qobject::qobject ( qobject * parent = 0 )
qobject::~qobject () [virtual]
void qobject::setparent ( qobject * parent )
注:這三個函式都是通過乙個內部私有函式來實現的,這就是

qobjectprivate::setparent_helper(qobject *o)
每個qobject只有乙個父物件:

qobject * qobject::parent () const
子物件可以有多個

const qobjectlist & qobject::children () const
所以可以根據條件來查詢嘍:

t qobject::findchild ( const qstring & name = qstring() ) const

qlistqobject::findchildren ( const qstring & name = qstring() ) const

deletelater 包含兩層意思了

呵呵,似乎這是廢話哈。

在去年春節前的時候吧,有人對

obj-> deletelater()
會像下面一樣呼叫delete:

delete obj;
感到不解。然後我寫了這樣乙個c++例子:

class a

void deleteme()

};int main()

應該不需要解釋吧

qt 是事件驅動的,所以傳送乙個刪除事件到事件系統就可以啦:

void qobject::deletelater()

事件迴圈稍後看到該事件就會將其派發會這個widget:

bool qobject::event(qevent *e)

qlabel label();

delete &label;

qlabel *label = new qlabel("hello qt!");

label.setparent(&w)

qwidget w;

qlabel label(tr"hello qt!");

qt 物件的父子關係的引入,簡化了我們對記憶體的管理,但是,由於它會在你不太注意的地方呼叫 delete,所以,使用時還是要當心。

從 Qt 的 delete 說開來

在c 中學習過程中,我們都知道 qt作為c 的庫,顯然是不會違背c 的前述原則的。可是 注 本文暫不涉及智慧型指標 smart pointer 相關的東西,你可以考慮 qt 智慧型指標學習 一文 在qt中,以下情況下你new出的物件你可以不用親自去delete 但你應該清楚delete在何處被qt呼...

從 Qt 的 delete 說開來

delete qtclass clist 目錄 在c 中學習過程中,我們都知道 qt作為c 的庫,顯然是不會違背c 的前述原則的。可是 注 本文暫不涉及智慧型指標 smart pointer 相關的東西,你可以考慮 qt 智慧型指標學習 一文 在qt中,以下情況下你new出的物件你可以不用親自去de...

從 Qt 的 delete 說開來

原文 在c 中學習過程中,我們都知道 qt作為c 的庫,顯然是不會違背c 的前述原則的。可是 注 本文暫不涉及智慧型指標 smart pointer 相關的東西,你可以考慮 qt 智慧型指標學習 一文 在qt中,以下情況下你new出的物件你可以不用親自去delete 但你應該清楚delete在何處被...