• <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>

            Heath's Blog

            There is no end, it is just the beginning! - A Game Developer's Notes

            Windows平臺下針對C/C++項目的內(nèi)存泄漏檢測方法

                 由于語言在自動內(nèi)存管理上的欠缺,C/C++在內(nèi)存管理上從來都是需要程序員小心處理的一個方面,當項目代碼上了一定規(guī)模,內(nèi)存消耗和泄漏就會成為程序穩(wěn)定運行的第一大敵。如果不在項目之初就建立內(nèi)存管理和泄漏檢測機制,后面蛋疼的問題就會接踵而來。這篇文章著重討論內(nèi)存泄漏檢測,而內(nèi)存管理與具體項目類型關系密切,后面有時間我會著重游戲項目來討論。

                 內(nèi)存泄漏檢測的基本步驟是:1)包裝(重載)內(nèi)存分配/釋放API;2)進行內(nèi)存分配時記下相關信息:地址、大小、調(diào)用棧;3)釋放時清除之前記錄的對應信息;4)程序退出時(確保在所有內(nèi)存釋放操作完成之后),輸出剩下的記錄。其中,對進行分配操作是的調(diào)用棧回溯是個重點信息,它能夠幫助我們找出內(nèi)存泄漏代碼。

                 Windows中的Dbghelp庫提供了豐富的調(diào)試API。StackWalk應該是進行棧回溯最直接的一種接口了,但是它不夠快。如果能先記錄下調(diào)用棧上的CALL指令地址,然后在輸出日志時解析出符號,將會大大降低檢測機制對程序本身性能的影響。Dbghelp庫中提供了Sym*FromAddr系列API,可以通過指令地址獲取函數(shù)符號,那么剩下的就是如何記錄指令地址的問題了。從網(wǎng)上借了一張x86調(diào)用棧示意圖,如下:

            Image(12)

                 從圖中可以看出,Callee的EBP始終指向Caller的EBP,EBP下面是指向Caller下一條指令(注意x86體系下棧的增長方向是小地址),因此通過EBP就可以回溯整個調(diào)用棧了。通過下面代碼可以實現(xiàn)此功能:

            Image(13)

                 宏參數(shù)frame是個void*指針數(shù)組,數(shù)組的大小取決于想要回溯的棧深度。內(nèi)存分配和回收的包裝代碼如下:

            Image(14)

                 我們看到,內(nèi)存管理系統(tǒng)內(nèi)部終究還是要使用語言提供的內(nèi)存分配/釋放API,只要配對實現(xiàn)了分配與釋放管理,系統(tǒng)內(nèi)部的無泄漏是很容易保證的。在這里著重講解原理,就不重載new/delete operator了。最后看一下調(diào)用棧函數(shù)符號的回溯代碼:

            Image(15)

                 我們用下面代碼做測試用例:

            Image(16)

                 泄漏檢測結果:

            Image(17)

            參考:

            [1] Using DbgHelp

            [2] Intel x86 Function-call Conventions - Assembly View

            posted on 2013-10-26 08:55 Heath 閱讀(4422) 評論(4)  編輯 收藏 引用 所屬分類: Game Development

            Feedback

            # re: Windows平臺下針對C/C++項目的內(nèi)存泄漏檢測方法 2013-10-26 09:39 戰(zhàn)魂小筑

            windows下VLD搞定, 還開源, 都不用研究了  回復  更多評論   

            # re: Windows平臺下針對C/C++項目的內(nèi)存泄漏檢測方法[未登錄] 2013-10-28 10:26 Heath

            @戰(zhàn)魂小筑
            VLD這么好用,但為什么很多游戲引擎都會自己寫一套內(nèi)存管理和檢測機制呢?  回復  更多評論   

            # re: Windows平臺下針對C/C++項目的內(nèi)存泄漏檢測方法 2013-10-28 20:59 孤獨劍客zzy

            這個非常有用,可以簡單的實現(xiàn)valgrind了,必須頂!!!  回復  更多評論   

            # re: Windows平臺下針對C/C++項目的內(nèi)存泄漏檢測方法 2013-11-20 21:12 GLimix

            這方面的文章不多,好文。  回復  更多評論   

            色婷婷综合久久久中文字幕 | 无码人妻久久一区二区三区蜜桃| 伊人久久大香线蕉av不变影院| 色综合合久久天天综合绕视看 | 久久天天躁狠狠躁夜夜躁2O2O| 91精品国产乱码久久久久久| 精品久久久无码中文字幕| 久久久久久精品成人免费图片| 久久精品一区二区三区中文字幕| 激情久久久久久久久久| 亚洲国产精品久久66| 91精品免费久久久久久久久| 久久综合久久综合久久综合| 亚洲精品美女久久777777| 精品综合久久久久久97| 无码国内精品久久人妻蜜桃| 久久国产亚洲精品无码| 久久99精品久久久久久hb无码 | www亚洲欲色成人久久精品| 久久国产香蕉视频| 人妻无码精品久久亚瑟影视| 久久久亚洲欧洲日产国码是AV| 亚洲女久久久噜噜噜熟女| 久久99国产精品久久99| 国产精品热久久无码av| 少妇人妻综合久久中文字幕| 国内精品久久久久影院优| 久久精品国产一区二区三区不卡| 久久精品视频一| 久久超碰97人人做人人爱| 国产精久久一区二区三区| 国产亚洲精品久久久久秋霞| 成人国内精品久久久久影院| 久久久网中文字幕| 狼狼综合久久久久综合网| 久久久久国产精品嫩草影院 | 国产福利电影一区二区三区久久老子无码午夜伦不 | 国产产无码乱码精品久久鸭| 久久精品国产精品亚洲| 久久精品水蜜桃av综合天堂| 色天使久久综合网天天 |