• <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>
            Impossible is nothing  
              愛過知情重醉過知酒濃   花開花謝終是空   緣份不停留像春風來又走   女人如花花似夢
            公告
            日歷
            <2025年6月>
            25262728293031
            1234567
            891011121314
            15161718192021
            22232425262728
            293012345
            統(tǒng)計
            • 隨筆 - 8
            • 文章 - 91
            • 評論 - 16
            • 引用 - 0

            導航

            常用鏈接

            留言簿(4)

            隨筆分類(4)

            隨筆檔案(8)

            文章分類(77)

            文章檔案(91)

            相冊

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

             
            在堆上分配內存
            可能許多人對內存分配上的“棧 stack”和“堆 heap”還不是很明白。包括一些科班出身的人也不明白這兩個概念。簡單的來講,stack上分配的內存系統(tǒng)自動釋放, heap上分配的內存,系統(tǒng)不釋放,哪怕程序退出,那一塊內存還是在那里。stack一般是靜態(tài)分配內存,heap上一般是動態(tài)分配內存。
            malloc系統(tǒng)函數分配的內存就是從堆上分配內存。從堆上分配的內存一定要自己釋放。用free釋放,不然就是術語——“內存泄露”(或是“內存漏洞”)—— Memory Leak。于是,系統(tǒng)的可分配內存會隨malloc越來越少,直到系統(tǒng)崩潰。還是來看看“棧內存”和“堆內存”的差別吧。
            內存分配:(典型的函數:alloca

            char* AllocStrFromStack()
            {
               char pstr[100];
               return pstr;
            }
            堆內存分配:(典型的函數:malloc
            char* AllocStrFromHeap(int len)
            {
               char *pstr;
               if ( len <= 0 ) return NULL;
               return ( char* ) malloc( len );
            }
            堆內存分配:(典型的函數:malloc
            char* AllocStrFromHeap(int len)
            {
               char *pstr;
               if ( len <= 0 ) return NULL;
               return ( char* ) malloc( len );
            }

            對于第一個函數,那塊pstr的內存在函數返回時就被系統(tǒng)釋放了。于是所返回的char*什么也沒有。而對于第二個函數,是從堆上分配內存,所以哪怕是程序退出時,也不釋放,所以第二個函數的返回的內存沒有問題,可以被使用。但一定要調用free釋放,不然就是Memory Leak
            對于第一個函數,那塊pstr的內存在函數返回時就被系統(tǒng)釋放了。于是所返回的char*什么也沒有。而對于第二個函數,是從堆上分配內存,所以哪怕是程序退出時,也不釋放,所以第二個函數的返回的內存沒有問題,可以被使用。但一定要調用free釋放,不然就是Memory Leak

            在堆上分配內存很容易造成內存泄漏,這是C/C++的最大的“克星”,如果你的程序要穩(wěn)定,那么就不要出現(xiàn)Memory Leak
            剛好前一段時間有一個Linux上的服務應用程序,大約有幾百的C文件編譯而成,運行測試良好,等使用時,時間一長內存占用率就偏高,搞得許多人焦頭爛額,查不出問題所在。出現(xiàn)這種問題就是MemeryLeak做怪了,在C/C++中這種問題總是會發(fā)生,所以你一定要小心。一個Rational的檢測工作——Purify,可以幫你測試你的程序有沒有內存泄漏。我保證,做過許多C/C++的工程的程序員,都會對malloc或是new有些感冒。當你什么時候在使用mallocnew時,有一種輕度的緊張和惶恐的感覺時,你就具備了這方面的修養(yǎng)了。

            對于mallocfree的操作有以下規(guī)則:
            1)
            配對使用,有一個malloc,就應該有一個free。(C++中對應為newdelete
            2)
            盡量在同一層上使用,不要像上面那種,malloc在函數中,而free在函數外。最好在同一調用層上使用這兩個函數。
            3) malloc
            分配的內存一定要初始化。free后的指針一定要設置為NULL
            4)
            設計自己的內存分配鏈表,記載已經分配的內存,便于在釋放的時候有備可查
            注:雖然現(xiàn)在的操作系統(tǒng)(LinuxWindows)都有進程內存跟蹤機制,也就是如果你有沒有釋放的內存,操作系統(tǒng)會幫你釋放。但操作系統(tǒng)依然不會釋放你程序中所有產生了Memory Leak的內存,所以,最好還是你自己來做這個工作。
            posted on 2006-02-26 12:59 笑笑生 閱讀(239) 評論(0)  編輯 收藏 引用 所屬分類: C++語言
             
            Copyright © 笑笑生 Powered by: 博客園 模板提供:滬江博客
            国产午夜精品久久久久九九| 久久人人爽人人爽人人片AV东京热| 熟妇人妻久久中文字幕| 伊人热人久久中文字幕| 久久精品国产第一区二区| 亚洲人成网站999久久久综合| 思思久久99热免费精品6| 亚洲日韩欧美一区久久久久我 | 亚洲美日韩Av中文字幕无码久久久妻妇 | 日韩亚洲欧美久久久www综合网 | 日韩美女18网站久久精品| 一极黄色视频久久网站| 国产一级持黄大片99久久| 一97日本道伊人久久综合影院| 亚洲国产精品一区二区三区久久| 国产69精品久久久久APP下载 | 91精品国产高清久久久久久国产嫩草| 思思久久精品在热线热| 精品国产青草久久久久福利| 国产亚洲美女精品久久久久狼| 亚洲AV无码久久寂寞少妇| 国产精品热久久无码av| 国产高潮国产高潮久久久| 国产精品一区二区久久精品涩爱 | 久久国产色AV免费看| 国产成人久久久精品二区三区 | 亚洲精品NV久久久久久久久久| 久久99热精品| 亚洲国产成人精品无码久久久久久综合 | 精品熟女少妇a∨免费久久| 狠狠综合久久综合中文88| 99国产精品久久| 久久AⅤ人妻少妇嫩草影院| 97久久国产亚洲精品超碰热| 亚洲国产视频久久| 无码国产69精品久久久久网站| 久久精品国产72国产精福利| 久久久久人妻精品一区| 久久精品水蜜桃av综合天堂| 国内精品久久久久影院优| 性高湖久久久久久久久|