• <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>
            隨筆-22  評論-7  文章-0  trackbacks-0
            1#ifdef _DEBUG
            2#define new DEBUG_NEW
            3#undef THIS_FILE
            4static char THIS_FILE[] = __FILE__;
            5#endif

            對于這段代碼的作用,通常有一下解釋:

             

                    這個是為了VC檢測內存泄露而定義的, 只在 Debug 版本中;

                    曾經一個解釋說,多次使用__FILE__宏,雖然得到字符串的內容相同,但是可能地址不同,即同一個字符串常量多次用到時占用不同的地址,這樣導致需要的內存增加了。為了檢測內在泄露, Debug 版本的 new 附加上了調用 new 的文件名與調用所在的行號信息, 這是通過 __FILE__ 和 __LINE__ 來實現的, 這兩個屬于預定義的內部宏, 而之所以要用 THIS_FILE 來代替 __FILE__, 是為了減少程序大小: 如果你在一個文件中有 10000 次對 new 的調用, 那么會生成 10000 個當前文件名的常量字符串(第一個都是由 __FILE__ 宏擴展而來的), 最后生成的目標文件會很大, 而用 THIS_FILE 來代替, 當前文件名只有一份, 傳遞文件名使用 THIS_FILE 指針就可以了。
                        __FILE__和__LINE__一樣都是編譯器定義的宏。當碰到__FILE__時,編譯器會把__FILE__替換成一個字符串,這個字符串就是當前在編譯的文件的路徑名。在DEBUG_NEW的定義中沒有直接使用__FILE__,而是用了THIS_FILE,其目的是為了減小目標文件的大小。假設在某個cpp文件中有100處使用了new,如果直接使用__FILE__,那編譯器會產生100個常量字符串,這100個字符串都是這個cpp文件的路徑名,顯然十分冗余。如果使用THIS_FILE,編譯器只會產生一個常量字符串,那100處new的調用使用的都是指向常量字符串的指針。    
            在   MFC   中,可以使用   DEBUG_NEW   宏代替   new   運算符來幫助定位內存泄漏。在程序的“Debug”版本中,DEBUG_NEW   將為所分配的每個對象跟蹤文件名和行號。當編譯程序的“Release”版本時,DEBUG_NEW   將解析為不包含文件名和行號信息的簡單   new   操作。因此,在程序的“Release”版本中不會造成任何速度損失。  
               
              如果不想重寫整個程序來使用   DEBUG_NEW   代替   new,則可以在源文件中定義下面的宏:  
               
              #define   new   DEBUG_NEW  
              當進行對象轉儲時,用   DEBUG_NEW   分配的每個對象均將顯示被分配到的文件和行號,使您可以查明內存泄漏源。  
               
              MFC   框架的“Debug”版本自動使用   DEBUG_NEW,但代碼不自動使用它。如果希望利用   DEBUG_NEW   的好處,則必須顯式使用   DEBUG_NEW   或   #define   new,如上所示。  
            總起來講,這段代碼的作用就是防止內存泄露,減小程序編譯開銷的。


            本文來自CSDN博客,轉載請標明出處:http://blog.csdn.net/Ronger0828/archive/2009/01/11/3750962.aspx

            posted on 2010-04-20 15:58 楚天清秋 閱讀(548) 評論(0)  編輯 收藏 引用 所屬分類: VC++
            老司机国内精品久久久久| 波多野结衣AV无码久久一区| 国产精品久久99| 亚洲精品高清国产一久久| 精品水蜜桃久久久久久久| 久久影院亚洲一区| 久久香蕉超碰97国产精品| 久久精品视频一| 久久午夜综合久久| 亚洲精品乱码久久久久久| 狠狠色噜噜狠狠狠狠狠色综合久久| 久久精品一区二区国产| 亚洲伊人久久综合中文成人网| 亚洲av成人无码久久精品| 国产午夜精品理论片久久| 日韩AV无码久久一区二区| 久久性精品| 久久久国产精品网站| 久久久国产打桩机| 久久精品国产亚洲精品| 精品国产乱码久久久久久1区2区| 久久久人妻精品无码一区 | 99久久精品国产毛片| 久久99精品久久久大学生| 国产精品伊人久久伊人电影| 久久天天躁狠狠躁夜夜网站| 欧美久久一区二区三区| 久久中文娱乐网| 99久久99这里只有免费的精品| 成人午夜精品无码区久久| 伊人色综合久久天天网| 久久93精品国产91久久综合| 精品亚洲综合久久中文字幕| 亚洲AV日韩精品久久久久久 | 久久夜色撩人精品国产| 99久久精品费精品国产一区二区| 亚洲精品乱码久久久久66| 麻豆精品久久久久久久99蜜桃 | 伊人久久精品无码二区麻豆| 久久人人青草97香蕉| 久久天天躁夜夜躁狠狠躁2022 |