• <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平臺(tái)下針對(duì)C/C++項(xiàng)目的內(nèi)存泄漏檢測(cè)方法

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

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

                 Windows中的Dbghelp庫(kù)提供了豐富的調(diào)試API。StackWalk應(yīng)該是進(jìn)行?;厮葑钪苯拥囊环N接口了,但是它不夠快。如果能先記錄下調(diào)用棧上的CALL指令地址,然后在輸出日志時(shí)解析出符號(hào),將會(huì)大大降低檢測(cè)機(jī)制對(duì)程序本身性能的影響。Dbghelp庫(kù)中提供了Sym*FromAddr系列API,可以通過(guò)指令地址獲取函數(shù)符號(hào),那么剩下的就是如何記錄指令地址的問(wèn)題了。從網(wǎng)上借了一張x86調(diào)用棧示意圖,如下:

            Image(12)

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

            Image(13)

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

            Image(14)

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

            Image(15)

                 我們用下面代碼做測(cè)試用例:

            Image(16)

                 泄漏檢測(cè)結(jié)果:

            Image(17)

            參考:

            [1] Using DbgHelp

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

            posted on 2013-10-26 08:55 Heath 閱讀(4423) 評(píng)論(4)  編輯 收藏 引用 所屬分類(lèi): Game Development

            Feedback

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

            windows下VLD搞定, 還開(kāi)源, 都不用研究了  回復(fù)  更多評(píng)論   

            # re: Windows平臺(tái)下針對(duì)C/C++項(xiàng)目的內(nèi)存泄漏檢測(cè)方法[未登錄](méi) 2013-10-28 10:26 Heath

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

            # re: Windows平臺(tái)下針對(duì)C/C++項(xiàng)目的內(nèi)存泄漏檢測(cè)方法 2013-10-28 20:59 孤獨(dú)劍客zzy

            這個(gè)非常有用,可以簡(jiǎn)單的實(shí)現(xiàn)valgrind了,必須頂?。。?nbsp; 回復(fù)  更多評(píng)論   

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

            這方面的文章不多,好文。  回復(fù)  更多評(píng)論   

            国产V亚洲V天堂无码久久久| 国内精品综合久久久40p| 久久久久久国产a免费观看黄色大片| 久久久久久国产精品无码下载| 国产精品热久久毛片| 午夜肉伦伦影院久久精品免费看国产一区二区三区 | 久久99精品久久久久久| 狠狠久久综合伊人不卡| 日韩精品久久久肉伦网站| 91久久精品国产91性色也| 久久亚洲私人国产精品| 2021少妇久久久久久久久久| 久久亚洲精品国产亚洲老地址| 色妞色综合久久夜夜| 国产成人精品久久亚洲高清不卡| 色婷婷久久久SWAG精品| 国产成人久久精品区一区二区| 久久狠狠一本精品综合网| 一本色道久久88—综合亚洲精品| 91精品国产高清久久久久久国产嫩草 | 久久精品国产精品亚洲| 亚洲国产精品无码久久久秋霞2| 亚洲v国产v天堂a无码久久| 久久久无码精品亚洲日韩蜜臀浪潮| 久久精品无码一区二区WWW| 亚洲综合久久夜AV | 中文字幕久久精品| 国内精品久久久久久中文字幕| 日韩精品久久久肉伦网站| 久久久久久免费视频| 亚洲精品乱码久久久久久蜜桃| 久久se精品一区精品二区| 久久久无码精品亚洲日韩蜜臀浪潮 | 欧美日韩久久中文字幕| 国产精品久久久香蕉| 精品无码久久久久久国产| 日韩欧美亚洲综合久久影院d3| 99久久精品国产麻豆| 欧美黑人激情性久久| 蜜臀av性久久久久蜜臀aⅴ| 一本色道久久88精品综合|