• <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>
            隨筆 - 64, 文章 - 11, 評論 - 12, 引用 - 0
            數據加載中……

            由visual studio 編譯優化而獲得的啟示

                    今天,在運行目前正在維護的產品后,我發現產品在跑完個別的測試用例后,出現了大量的內存泄漏。從visual studio 2008的輸出中看不到具體是哪個文件的new操作引起,在DEBUG版本中看不到是由哪個new分配的內存泄漏的原因是文件中沒有如下的宏。

            #ifdef _DEBUG

            #define new DEBUG_NEW

            #undef THIS_FILE

            static char THIS_FILE[] = __FILE__;

            #endif

            由于項目中的文件較多,如果到一個一個文件中去找,那是件枯燥而且乏味的工作, 而且難保不會有遺漏。所以我編寫了腳本來報告沒有這幾句的文件。

                     通過在文件中加上了上述的宏,我再次重新運行剛才產生內存泄漏的測試用例。這次我定位了泄漏的內存分配語句。所以為了調試上的方便,我們應保證文件中有如上的宏。找到了相關的分配語句就離解決這個錯誤近了,現在就是要找出遺漏的釋放點。

                     為了使用我以前安裝的共享版內存泄漏檢測工具,我將系統的時間改成6月份。可惜還是提示過了試用期不讓使用,所以還得靠自己。通過查閱代碼,找出了幾個可疑點,分別加上了恰當的語句,按一下build 后,剛巧有事就離開了。回來后發現看看沒有編譯錯誤,于是再測試用例,結果還是出現泄漏。于是我加上調試斷點來分析,可是程序根本不在斷點處停止。這讓我著實驚訝,難道程序并不經過這些斷點? 再放置幾個斷點,依然不停住,最后就在InitInstance()函數中放一斷點,可還是不停住。這時我才恍然大悟這個exe文件與代碼不一致。于是改回系統時間,重新build。再次運行,程序在斷點處停住,運行相應的測試用例,也不再有內存泄漏。

                     在這個過程中,由于visual studio的編譯行為所采用的時間比較來決定編譯的行為及本人的粗心讓我浪費了一些時間和精力。這也提示我們在設計軟件時,對于優化行為應多加考慮,行為的優化是否符合了用戶的企圖,如果與用戶的動作不符合,則應給用戶提示并得到用戶的指示。

            posted on 2009-07-23 16:01 Robertxiao 閱讀(526) 評論(0)  編輯 收藏 引用 所屬分類: 天馬行空

            久久久噜噜噜久久中文字幕色伊伊| 久久精品一本到99热免费| 成人午夜精品无码区久久| 久久人妻无码中文字幕| 久久精品国产清高在天天线| 中文字幕成人精品久久不卡 | 国产成人无码久久久精品一| 亚洲国产日韩欧美综合久久| 国产亚洲精品久久久久秋霞| 国产亚洲欧美成人久久片| 久久久久亚洲精品天堂久久久久久 | 久久精品亚洲福利| 久久久91人妻无码精品蜜桃HD| 日本亚洲色大成网站WWW久久| 精品久久久久久中文字幕大豆网| 熟妇人妻久久中文字幕| 99久久国产综合精品网成人影院 | 超级碰久久免费公开视频| AV狠狠色丁香婷婷综合久久| 日韩欧美亚洲综合久久影院Ds| 99精品国产综合久久久久五月天| 久久99国产精品一区二区| 色播久久人人爽人人爽人人片aV| 99久久777色| 综合网日日天干夜夜久久| 欧美日韩精品久久久久| 久久综合九色综合97_久久久| 亚洲欧美日韩精品久久亚洲区| 青青草原综合久久大伊人精品| 久久久久亚洲精品男人的天堂| 老司机国内精品久久久久| 一本久久知道综合久久| 久久婷婷五月综合成人D啪| 久久se精品一区精品二区| 东方aⅴ免费观看久久av| 久久99这里只有精品国产| 亚洲一区精品伊人久久伊人| 韩国三级中文字幕hd久久精品| 久久精品国产亚洲Aⅴ香蕉| 国产精品美女久久久网AV| 日韩精品久久久久久|