• <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>
            隨筆-1  評論-9  文章-16  trackbacks-0
                    這幾天想提高一下自己的debug水平,于是看了下熊力寫的那那個《windows用戶態程序高效排錯》,里邊有個比較有趣的問題,下邊的程序的debug版本比release的版本要快,為什么?
                int nSize=200;
                
            char *pSource=(char *)malloc(nSize+1);
                
            if(pSource==NULL)
                     
            return 0;
                
            char *pDest=(char *)malloc(nSize+1);
                
            if(pDest==NULL)
                     
            return 0;
                memset(pSource,
            'a',nSize);
                pSource[nSize]
            ='\0';
                DWORD dwStart
            =GetTickCount();
                
            for(int i=0;i<5000000;i++)
                
            {
                   strcpy(pDest,pSource);
                }

                DWORD dwend
            =GetTickCount();
                printf(
            "%d\n",dwend-dwStart);

                 當然對于我這種小菜肯定是不容易懂清楚的了,于是找了很多資料,才發現原來跟debugreleasestrcpy的函數類型有關的,前者是內聯函數(inline),而后者是直接調用運行時庫的(這個在IDA中可以清楚的看到),于是這5000000次的調用的差距就體現出來了.
                
            但是為什么同一個編譯器出來的執行文件出來的函數會有不同的類型呢?這就要扯到C運行時庫上邊了--Windows環境下,VC提供的 C run-time library分為動態運行時庫和靜態運行時庫。動態運行時庫主要是DLL庫文件msvcrt.dll(or MSVCRTD.DLL for debug build),對應的Import library文件是MSVCRT.LIB(MSVCRTD.LIB for debug build),而靜態運行時庫(release)對應的主要文件是:LIBC.LIB (Single thread static library, retail version),LIBCMT.LIB (Multithread static library, retail version).由于這些運行時庫的實現者不同,所實現的函數也就不同了,而對于這個有趣的問題我們可以看到在MSVCRT.LIBstrcpy是內聯函數,LIBC.LIBLIBCMT.LIB中的不是了.
            C運行時庫的相關文章在這:http://www.shnenglu.com/aqazero/archive/2007/09/21/14173.html

            posted on 2008-05-06 20:06 Lexili 閱讀(516) 評論(0)  編輯 收藏 引用
            无码伊人66久久大杳蕉网站谷歌| 久久久久亚洲av无码专区导航 | 久久国产成人午夜AV影院| 久久综合狠狠综合久久激情 | 国产99久久九九精品无码| 久久综合久久性久99毛片| 日韩精品久久久久久免费| 国产精品va久久久久久久| 久久久久久综合网天天| 久久免费高清视频| 日韩精品久久久久久久电影蜜臀| 国内精品久久久久久久亚洲| 亚洲av伊人久久综合密臀性色 | 国产亚洲精品久久久久秋霞 | 久久久久一区二区三区| 久久久国产打桩机| 久久精品国产99久久香蕉| 久久国产色AV免费看| 中文字幕精品久久| 国产精品嫩草影院久久| 国产亚洲婷婷香蕉久久精品| 久久精品成人欧美大片| 欧美激情精品久久久久久久九九九 | 97久久精品人人做人人爽| 亚洲中文字幕无码久久精品1| 久久高清一级毛片| 韩国三级中文字幕hd久久精品 | 久久久一本精品99久久精品66| 亚洲精品乱码久久久久久不卡| 国产精品99久久久久久www| 久久亚洲高清观看| 国产午夜精品理论片久久影视| 无码精品久久久天天影视| 99久久夜色精品国产网站| 久久精品人人做人人爽电影| 亚洲国产日韩综合久久精品| 一本久久a久久精品综合香蕉 | 久久亚洲精品无码aⅴ大香| 一级a性色生活片久久无少妇一级婬片免费放 | 久久天堂AV综合合色蜜桃网| 久久久久国产精品熟女影院 |