Qt的記憶體管理

2021-05-23 13:12:10 字數 1040 閱讀 6402

在qt的程式中經常會看到只有new而不delete的情況,其實是因為qt有一套**記憶體的機制,主要的規則如下:

1.所有繼承自qobject類的類,如果在new的時候指定了父親,那麼它的清理時在父親被delete的時候delete的,所以如果乙個程式中,所有的qobject類都指定了父親,那麼他們是會一級級的在最上面的父親清理時被清理,而不用自己清理;

3.這是有人可能會問那如果我自行delete掉這些qt接管負責銷毀的指標了會出現什麼情況呢,如果時這樣的話,正常情況下qt的擁有這個物件的 那個父親會知道這件事情,它會直到它的兒子被你直接delete了,這樣它會將這個兒子移出它的列表,並且重新構建顯示內容,但是直接這樣做時有風險的! 也就是要說的下一條

4.當乙個qobject正在接受事件佇列時如果中途被你delete掉了,就是出現問題了,所以qt中建議大家不要直接delete掉乙個 qobject,如果一定要這樣做,要使用qobject的deletelater()函式,它會讓所有事件都傳送完一切處理好後馬上清除這片記憶體,而且 就算呼叫多次的deletelater也不會有問題。

5.qt不建議在乙個qobject 的父親的範圍之外持有對這個qobject的指標,因為如果這樣外面的指標很可能不會察覺這個qobject被釋放,會出現錯誤,如果一定要這樣,就要記 住你在哪這樣做了,然後抓住那個被你違規使用的qobject的destroyed()訊號,當它沒有時趕快置零你的外部指標。當然我認為這樣做是及其麻 煩也不符合高效率程式設計規範的,所以如果要這樣在外部持有qobject的指標,建議使用引用或者用智慧型指標,如qt就提供了智慧型指標針對這些情況,見最後 一條。

6.qt中的智慧型指標封裝為qpointer類,所有qobject的子類都可以用這個智慧型指標來包裝,很多用法與普通指標一樣,可以詳見qt assistant

通過調查這個qt的記憶體管理功能,發現了很多東西,現在覺得雖然這個qt弄的有點小複雜,但是使用起來還是很方便的,最後要說的是某些記憶體洩露的檢測工具會認為qt的程式因為這種方式存在記憶體洩露,發現時大可不必理會~ ~

QT記憶體管理

使用new操作符來定義乙個物件 qvboxlayout layout new qvboxlayout window 另外一種方法 qvboxlayout layout window c 並沒有提供記憶體自動管理機制,通常,需要程式開發人員自己去做這些事情,比如在建構函式中使用了new去申請了乙個物件...

六 Qt記憶體管理

父子關係 所有指定了父物件的qt物件 繼承自qobject類的例項 與其父物件間存在父子關係 每個qt物件都儲存有指向其所有子物件的指標 每個qt物件都有乙個指向其父物件的指標 當指定 通過建構函式指定,或通過setparent函式 qt物件的父物件時 其父物件會在子物件鍊錶中加入指向該物件的指標 ...

QT中對記憶體的管理

在qt中,一切繼承自qt自有類的類,如果存在parent指標,那麼當parent指標delete時,該類中的指標 它們都屬於parent指標對應的child指標 也會被delete。綜上,如果我們的視窗對應的類所對應的parent指標為null的話,我們還是要進行一次手動的記憶體管理。我這裡舉個例子...