• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            天下

            記錄修行的印記

            Qt的內存管理

            Qt的內存管理

            剛學Qt時,發現代碼里到處都是new,而基本上見不到delete,百度得知,Qt中內存管理機制:當new一個對象指定父親時,父親被銷毀時,會一并把自對象銷毀。

            在QT的程序中經常會看到只有new而不delete的情況,其實是因為QT有一套回收內存的機制,主要的規則如下:

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

            2.程序通常最上層會有一個根的QOBJECT,就是放在setCentralWidget()中的那個QOBJECT,這個QOBJECT在new的時候不必指定它的父親,因為這個語句將設定它的父親為總的QAPPLICATION,當整個QAPPLICATION沒有時它就自動清理,所以也無需清理。9這里QT4和QT3有不同,QT3中用的是setmainwidget函數,但是這個函數不作為里面QOBJECT的父親,所以QT3中這個頂層的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

            轉自:http://blog.csdn.net/leonwei/article/details/3703598

             

            posted on 2012-08-31 15:28 天下 閱讀(694) 評論(0)  編輯 收藏 引用 所屬分類: QT

            <2013年4月>
            31123456
            78910111213
            14151617181920
            21222324252627
            2829301234
            567891011

            導航

            統計

            常用鏈接

            留言簿(4)

            隨筆分類(378)

            隨筆檔案(329)

            鏈接

            最新隨筆

            搜索

            最新評論

            伊人久久大香线蕉综合影院首页| 亚洲国产精品久久久久婷婷软件| 亚洲国产婷婷香蕉久久久久久| 精品久久久久久无码免费| 久久精品亚洲精品国产欧美| 久久精品国产色蜜蜜麻豆| 成人国内精品久久久久影院| 伊人久久大香线蕉综合网站| 色偷偷偷久久伊人大杳蕉| 欧美一级久久久久久久大| 粉嫩小泬无遮挡久久久久久| 亚洲人成无码久久电影网站| 国产一区二区三区久久精品| 久久国产欧美日韩精品| 久久亚洲国产精品123区| 国产精品一区二区久久精品| 久久久久亚洲av成人网人人软件 | 亚洲国产日韩欧美综合久久| 久久精品黄AA片一区二区三区 | 日韩精品久久无码人妻中文字幕| 精品久久久久久国产三级| 国产美女久久精品香蕉69| 久久狠狠爱亚洲综合影院| 久久国产欧美日韩精品免费| 精品人妻伦一二三区久久| 欧美综合天天夜夜久久| 久久99精品国产99久久| 久久er99热精品一区二区| 久久久婷婷五月亚洲97号色| 人妻精品久久无码专区精东影业 | 久久国产精品久久久| 国产精品久久久亚洲| 97久久精品无码一区二区| 久久精品国产久精国产思思| 久久精品国产亚洲AV无码麻豆| 亚洲精品乱码久久久久久中文字幕| 99久久精品免费看国产一区二区三区 | 久久综合亚洲色HEZYO国产| 91麻精品国产91久久久久| 精品久久人人做人人爽综合| 亚洲国产精品综合久久一线|