從 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() ) constdeletelater 包含兩層意思了qlistqobject::findchildren ( const qstring & name = qstring() ) const
呵呵,似乎這是廢話哈。
在去年春節前的時候吧,有人對
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;qt 物件的父子關係的引入,簡化了我們對記憶體的管理,但是,由於它會在你不太注意的地方呼叫 delete,所以,使用時還是要當心。qlabel label(tr"hello qt!");
從 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在何處被...