• <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>
            隨筆-16  評論-116  文章-0  trackbacks-0
            轉載請注明出處http://www.shnenglu.com/greatws/archive/2008/04/22/47783.html

            今天突發奇想想玩玩C的內聯匯編,以前也經常在DOS下玩debug,那就先整個最簡單的MessageBox玩玩咯
            網上找了一段代碼
             char* lpCaption="111";
             
            char* lpText="222";

            _asm  
             
            {  
              push MB_OK  
              lea eax,lpCaption 
              push eax 
              lea eax,lpText
              push eax 
              push NULL
              call dword ptr [MessageBoxA]  
            }


            于是在VC9下建了一個Dialog工程,MFC,然后在一個Button事件下加入這段代碼,鼠標在MessageBoxA上放了下,一看CWnd::MessageBox...3個參數,而上面代碼中push了4個參數,汗一個,那就去掉最后一個參數句柄吧,編譯---運行---點一下Button,居然標題和內容都是亂碼。。。回到VC開始調試,看看問題出在哪里。進入反匯編窗口,看lpCaption的值是0x00424da4,F8單步(為了和OD一致,我改成了F8),執行lea eax,lpCaption ,一看eax的值,嚇一跳,變成0x0012f878...汗一個,怎么就變成這個了。仔細一想,lpCation是一個char*指針類型, lpCaption指向的地址是0x00424da4,當然lpCaption也是存在內存某一地址中的,估計lea把lpCation所在的內存地址送到eax,沒有將其中的值送到eax,于是改成mov試試
            _asm  
             
            {  
              push MB_OK  
              mov eax,lpCaption 
              push eax 
              mov eax,lpText
              push eax 
              call dword ptr [MessageBoxA]  
            }



            這下就沒有問題了,真汗,從中學一直被忽悠到大學....

            接下來來測試一C內聯asm和C下那個效率更高,為了方便查看,來直接調用API的MessageBox,但是不能call dword ptr [::MessageBoxA],那就用函數指針吧- -
            typedef int (__stdcall* messageboxfunc)(HWND,LPCTSTR,LPCTSTR,UINT);
             
            char* lpCaption="111";
             
            char* lpText="222";
             messageboxfunc api_messagebox
            =::MessageBoxA;
             _asm  
             
            {  
              
              push MB_OK  
              mov eax,lpCaption 
              push eax 
              mov eax,lpText
              push eax 
              push NULL
              call dword ptr [api_messagebox]  
              
             }

            //寫一個直接調用MessageBox的函數,等下用OD調試看看代碼情況
            api_messagebox(NULL,lpText,lpCaption,MB_OK);



            OD調試的截圖
            第一行是我的::MessageBox函數指針,到call dword ptr [ebp-4]用了9行...用了29個字節,mov-mov-mov-push-mov-push-mov-push-push,好花啊,而直接使用函數調用API(后那個call esi,esi在上面就是mov esi,dword ptr [<&USER32.MessageBoxA>],函數指針嘛),4個連續的push外加一個call則只用了14個字節,my god!!!!!C內聯asm反而效率低?還是編譯器不對這些代碼進行優化?成為傳說中的“花指令”?

            由此可見,VC的代碼優化非常的好,一般不要輕易用內聯asm,除非是超高手或者迫不得已~~HOHO,但是用C內聯匯編寫一些花指令還是不錯的,比如說把jmp 00420000寫成
            jz 00420000
            nop
            nop
            nop
            nop
            jnz 00420000

            HOHO,對軟件加密有所幫助
            by gratws
            posted on 2008-04-22 01:39 greatws 閱讀(6167) 評論(12)  編輯 收藏 引用

            評論:
            # re: 被忽悠了,一直以為lea和mov指令差不多的,今天算是知道了,順便測試了下C內聯匯編的效率 2008-04-22 09:15 | 夢在天涯
            haha!超級高手!期待更多的!  回復  更多評論
              
            # re: 被忽悠了,一直以為lea和mov指令差不多的,今天算是知道了,順便測試了下C內聯匯編的效率 2008-04-22 09:24 | xxx
            沒有學好匯編,不是被忽悠  回復  更多評論
              
            # re: 被忽悠了,一直以為lea和mov指令差不多的,今天算是知道了,順便測試了下C內聯匯編的效率 2008-04-22 09:37 | 陳梓瀚(vczh)
            lea是Load Efficient Address啊,跟Mov咋能一樣……  回復  更多評論
              
            # re: 被忽悠了,一直以為lea和mov指令差不多的,今天算是知道了,順便測試了下C內聯匯編的效率 2008-04-22 09:46 | lonkil
            呵呵,lea是傳地址,mov是賦值.

            內聯那段分析的有道理,學習了.以后寫代碼的時候要主意了.
              回復  更多評論
              
            # 關于內聯指令不是很明白 2008-04-22 22:15 | herculesinchina
            關于反匯編代碼寫的不清楚,看不大懂你的意思。
            若說內聯效率有時低,那可能是因為編譯器要在內聯指令的前后為某些寄存器賦值,若你的內聯代碼較少,則編譯器的準備工作就顯得多了。  回復  更多評論
              
            # re: 被忽悠了,一直以為lea和mov指令差不多的,今天算是知道了,順便測試了下C內聯匯編的效率 2008-04-23 13:10 | 空明流轉
            lea和mov差遠了去了。。。  回復  更多評論
              
            # re: 被忽悠了,一直以為lea和mov指令差不多的,今天算是知道了,順便測試了下C內聯匯編的效率 2008-04-23 13:48 | faint
            lea ,mov大學學的時候老師就說了嘛,“要注意區分”  回復  更多評論
              
            # re: 被忽悠了,一直以為lea和mov指令差不多的,今天算是知道了,順便測試了下C內聯匯編的效率 2008-04-24 20:59 | AMXTSHMF
            = =!  回復  更多評論
              
            # re: 被忽悠了,一直以為lea和mov指令差不多的,今天算是知道了,順便測試了下C內聯匯編的效率 2008-04-27 19:47 | greatws
            @faint
            我老師怎么沒給我說過...  回復  更多評論
              
            # re: 被忽悠了,一直以為lea和mov指令差不多的,今天算是知道了,順便測試了下C內聯匯編的效率 2008-08-29 10:44 | xufan
            好想學喔..可以教我嗎  回復  更多評論
              
            # re: 被忽悠了,一直以為lea和mov指令差不多的,今天算是知道了,順便測試了下C內聯匯編的效率 2008-11-12 09:21 | 似水之心
            自學的匯編,書上沒有lea,找到這兒來了,原來這個樣子,謝謝了

            改個錯字  回復  更多評論
              
            # shi 2010-08-23 16:35 | uk dress
            That's good  回復  更多評論
              
            少妇被又大又粗又爽毛片久久黑人 | 亚洲欧美成人综合久久久| 超级碰碰碰碰97久久久久| 色综合久久夜色精品国产| 人妻少妇久久中文字幕一区二区 | 国产精品99久久久久久宅男| 久久精品无码av| 99久久精品日本一区二区免费| 99久久人人爽亚洲精品美女| 综合久久一区二区三区 | 国产69精品久久久久APP下载| 久久亚洲精品无码AV红樱桃| 国内精品久久久久久久亚洲| 国产成人精品综合久久久| 26uuu久久五月天| 久久99亚洲网美利坚合众国| 无码乱码观看精品久久| 日本精品久久久久中文字幕8| 综合网日日天干夜夜久久| 久久人人爽人人爽人人片AV东京热 | 91久久国产视频| 久久久久AV综合网成人| AV无码久久久久不卡蜜桃| 久久久久亚洲精品无码网址| 久久精品嫩草影院| 性色欲网站人妻丰满中文久久不卡| 久久午夜无码鲁丝片午夜精品| 久久综合丁香激情久久| 激情伊人五月天久久综合| 三上悠亚久久精品| 99久久99久久精品国产片果冻 | 久久人人爽人人人人片av| 国产精品美女久久久免费| 99久久综合狠狠综合久久止| 久久精品国产99久久无毒不卡| 精品综合久久久久久98| 久久天天婷婷五月俺也去| 亚洲AⅤ优女AV综合久久久| 手机看片久久高清国产日韩| 亚洲&#228;v永久无码精品天堂久久 | 97香蕉久久夜色精品国产 |