• <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  評(píng)論-116  文章-0  trackbacks-0
            轉(zhuǎn)載請(qǐng)注明出處http://www.shnenglu.com/greatws/archive/2008/04/22/47783.html

            今天突發(fā)奇想想玩玩C的內(nèi)聯(lián)匯編,以前也經(jīng)常在DOS下玩debug,那就先整個(gè)最簡(jiǎn)單的MessageBox玩玩咯
            網(wǎng)上找了一段代碼
             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下建了一個(gè)Dialog工程,MFC,然后在一個(gè)Button事件下加入這段代碼,鼠標(biāo)在MessageBoxA上放了下,一看CWnd::MessageBox...3個(gè)參數(shù),而上面代碼中push了4個(gè)參數(shù),汗一個(gè),那就去掉最后一個(gè)參數(shù)句柄吧,編譯---運(yùn)行---點(diǎn)一下Button,居然標(biāo)題和內(nèi)容都是亂碼。。。回到VC開(kāi)始調(diào)試,看看問(wèn)題出在哪里。進(jìn)入反匯編窗口,看lpCaption的值是0x00424da4,F(xiàn)8單步(為了和OD一致,我改成了F8),執(zhí)行l(wèi)ea eax,lpCaption ,一看eax的值,嚇一跳,變成0x0012f878...汗一個(gè),怎么就變成這個(gè)了。仔細(xì)一想,lpCation是一個(gè)char*指針類型, lpCaption指向的地址是0x00424da4,當(dāng)然lpCaption也是存在內(nèi)存某一地址中的,估計(jì)lea把lpCation所在的內(nèi)存地址送到eax,沒(méi)有將其中的值送到eax,于是改成mov試試
            _asm  
             
            {  
              push MB_OK  
              mov eax,lpCaption 
              push eax 
              mov eax,lpText
              push eax 
              call dword ptr [MessageBoxA]  
            }



            這下就沒(méi)有問(wèn)題了,真汗,從中學(xué)一直被忽悠到大學(xué)....

            接下來(lái)來(lái)測(cè)試一C內(nèi)聯(lián)asm和C下那個(gè)效率更高,為了方便查看,來(lái)直接調(diào)用API的MessageBox,但是不能call dword ptr [::MessageBoxA],那就用函數(shù)指針吧- -
            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]  
              
             }

            //寫(xiě)一個(gè)直接調(diào)用MessageBox的函數(shù),等下用OD調(diào)試看看代碼情況
            api_messagebox(NULL,lpText,lpCaption,MB_OK);



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

            由此可見(jiàn),VC的代碼優(yōu)化非常的好,一般不要輕易用內(nèi)聯(lián)asm,除非是超高手或者迫不得已~~HOHO,但是用C內(nèi)聯(lián)匯編寫(xiě)一些花指令還是不錯(cuò)的,比如說(shuō)把jmp 00420000寫(xiě)成
            jz 00420000
            nop
            nop
            nop
            nop
            jnz 00420000

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

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

            內(nèi)聯(lián)那段分析的有道理,學(xué)習(xí)了.以后寫(xiě)代碼的時(shí)候要主意了.
              回復(fù)  更多評(píng)論
              
            # 關(guān)于內(nèi)聯(lián)指令不是很明白 2008-04-22 22:15 | herculesinchina
            關(guān)于反匯編代碼寫(xiě)的不清楚,看不大懂你的意思。
            若說(shuō)內(nèi)聯(lián)效率有時(shí)低,那可能是因?yàn)榫幾g器要在內(nèi)聯(lián)指令的前后為某些寄存器賦值,若你的內(nèi)聯(lián)代碼較少,則編譯器的準(zhǔn)備工作就顯得多了。  回復(fù)  更多評(píng)論
              
            # re: 被忽悠了,一直以為lea和mov指令差不多的,今天算是知道了,順便測(cè)試了下C內(nèi)聯(lián)匯編的效率 2008-04-23 13:10 | 空明流轉(zhuǎn)
            lea和mov差遠(yuǎn)了去了。。。  回復(fù)  更多評(píng)論
              
            # re: 被忽悠了,一直以為lea和mov指令差不多的,今天算是知道了,順便測(cè)試了下C內(nèi)聯(lián)匯編的效率 2008-04-23 13:48 | faint
            lea ,mov大學(xué)學(xué)的時(shí)候老師就說(shuō)了嘛,“要注意區(qū)分”  回復(fù)  更多評(píng)論
              
            # re: 被忽悠了,一直以為lea和mov指令差不多的,今天算是知道了,順便測(cè)試了下C內(nèi)聯(lián)匯編的效率 2008-04-24 20:59 | AMXTSHMF
            # re: 被忽悠了,一直以為lea和mov指令差不多的,今天算是知道了,順便測(cè)試了下C內(nèi)聯(lián)匯編的效率 2008-04-27 19:47 | greatws
            @faint
            我老師怎么沒(méi)給我說(shuō)過(guò)...  回復(fù)  更多評(píng)論
              
            # re: 被忽悠了,一直以為lea和mov指令差不多的,今天算是知道了,順便測(cè)試了下C內(nèi)聯(lián)匯編的效率 2008-08-29 10:44 | xufan
            好想學(xué)喔..可以教我嗎  回復(fù)  更多評(píng)論
              
            # re: 被忽悠了,一直以為lea和mov指令差不多的,今天算是知道了,順便測(cè)試了下C內(nèi)聯(lián)匯編的效率 2008-11-12 09:21 | 似水之心
            自學(xué)的匯編,書(shū)上沒(méi)有l(wèi)ea,找到這兒來(lái)了,原來(lái)這個(gè)樣子,謝謝了

            改個(gè)錯(cuò)字  回復(fù)  更多評(píng)論
              
            # shi 2010-08-23 16:35 | uk dress
            That's good  回復(fù)  更多評(píng)論
              

            只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問(wèn)   Chat2DB   管理


            三级片免费观看久久| 国产精品青草久久久久婷婷| 精品久久久久久无码中文字幕一区| 久久综合视频网| 久久久久久久久久久| 久久免费看黄a级毛片| 亚洲AV无码一区东京热久久| 久久久精品国产免大香伊| 浪潮AV色综合久久天堂| 91精品国产色综合久久| 99久久这里只有精品| 精品国产91久久久久久久a| 精品国产婷婷久久久| 日本精品久久久久久久久免费| 久久男人AV资源网站| 麻豆精品久久久久久久99蜜桃| 亚洲精品乱码久久久久66| 国产精品视频久久久| 国产亚洲精久久久久久无码AV| 婷婷久久综合九色综合绿巨人| 久久亚洲AV成人无码软件| 久久精品中文騷妇女内射| 99久久精品国产综合一区| 亚洲七七久久精品中文国产 | 午夜不卡久久精品无码免费| 欧美一区二区三区久久综合| 99久久国产综合精品成人影院| 思思久久99热免费精品6| 色偷偷88888欧美精品久久久| A级毛片无码久久精品免费| 久久国产亚洲精品| 国产成人久久精品二区三区| 人妻无码精品久久亚瑟影视| 久久精品一区二区国产| 久久99这里只有精品国产| 精品久久久久久亚洲| 人妻无码精品久久亚瑟影视| 国产亚洲色婷婷久久99精品91| 精产国品久久一二三产区区别| 久久国产精品国产自线拍免费| 中文字幕无码久久精品青草 |