• <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精品国产免费久久久久久下载| 久久精品成人欧美大片| 俺来也俺去啦久久综合网| 国产精品久久久久9999高清| 久久男人AV资源网站| 亚洲色大成网站WWW久久九九| 色综合久久最新中文字幕| 午夜福利91久久福利| 久久本道伊人久久| 国内高清久久久久久| 99热热久久这里只有精品68| 国产成人精品综合久久久| 久久久久无码精品国产app| 久久久久99精品成人片试看| 久久亚洲精品无码观看不卡| 国产V综合V亚洲欧美久久| 无码任你躁久久久久久| 精品久久综合1区2区3区激情| 7777久久亚洲中文字幕| 亚洲精品乱码久久久久久蜜桃不卡| 精品国产热久久久福利| 国产精品久久久久久| 久久精品国产亚洲av水果派| 伊人久久大香线蕉无码麻豆| 久久精品免费网站网| 国产免费久久精品99久久| 久久er国产精品免费观看2| 亚洲中文字幕无码久久综合网| 国产精品久久久久久久app| 久久久久久久综合综合狠狠| 精品熟女少妇aⅴ免费久久| 国产成人精品久久亚洲高清不卡 | 久久线看观看精品香蕉国产| 久久久亚洲欧洲日产国码二区| 人妻无码久久一区二区三区免费| 亚洲色婷婷综合久久| 无码AV中文字幕久久专区| 天堂久久天堂AV色综合|