• <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>

            天下

            記錄修行的印記

            C++普通成員函數的調用反匯編

            //源代碼
            #include <cstdio>
            #include 
            <cstdlib>
            class TA{
            public:    
                
            void show()
                {
                    printf(
            "%d \r\n",m_id);
                }
                
            void callShow()
                {
                    TA::show();
                }
                
            int m_id;
            };

            int main()
            {
                TA ta;
                ta.m_id 
            = 5;
                ta.callShow();
                ta.show();
                system(
            "pause");
                
            return 0;
            }

            //反匯編后的代碼

            int main()
            {
            00411B10  push        ebp  
            00411B11  mov         ebp,esp 
            00411B13  sub         esp,0CCh 
            00411B19  push        ebx  
            00411B1A  push        esi  
            00411B1B  push        edi  
            00411B1C  lea         edi,[ebp
            -0CCh] 
            00411B22  mov         ecx,33h 
            00411B27  mov         eax,0CCCCCCCCh 
            00411B2C  rep stos    dword ptr es:[edi] 
                TA ta;
                ta.m_id 
            = 5;
            00411B2E  mov         dword ptr [ta],
            5 
                ta.callShow();
            00411B35  lea         ecx,[ta] 
            00411B38  call        TA::callShow (411019h) 
                ta.show();
            00411B3D  lea         ecx,[ta] 
            00411B40  call        TA::show (4110EBh) 
                system(
            "pause");
            00411B45  mov         esi,esp 
            00411B47  push        offset 
            string "pause" (41573Ch) 
            00411B4C  call        dword ptr [__imp__system (4182C0h)] 
            00411B52  add         esp,
            4 
            00411B55  cmp         esi,esp 
            00411B57  call        @ILT
            +320(__RTC_CheckEsp) (411145h) 
                
            return 0;
            00411B5C  xor         eax,eax 
            }


            //callShow()反匯編
            void callShow()
                {
            00411490  push        ebp  
            00411491  mov         ebp,esp 
            00411493  sub         esp,0CCh 
            00411499  push        ebx  
            0041149A  push        esi  
            0041149B  push        edi  
            0041149C  push        ecx  
            0041149D  lea         edi,[ebp
            -0CCh] 
            004114A3  mov         ecx,33h 
            004114A8  mov         eax,0CCCCCCCCh 
            004114AD  rep stos    dword ptr es:[edi] 
            004114AF  pop         ecx  
            004114B0  mov         dword ptr [ebp
            -8],ecx 
                    TA::show();
            004114B3  mov         ecx,dword ptr [
            this] //這里是關鍵.
            004114B6  call        TA::show (4110EBh) 
                }
            004114BB  pop         edi  
            004114BC  pop         esi  
            004114BD  pop         ebx  
            004114BE  add         esp,0CCh 
            004114C4  cmp         ebp,esp 
            004114C6  call        @ILT
            +320(__RTC_CheckEsp) (411145h) 
            004114CB  mov         esp,ebp 
            004114CD  pop         ebp  
            004114CE  ret         


            總結:C++成員函數調用 即this call 調用約定
            thiscall
            它是C
            ++類成員函數缺省的調用約定。

            參數從右向左入棧
            如果參數個數確定

            也就是把類的實例,即對象的地址(或者說把this指針)通過ecx傳遞到調用函數,
            調用的函數通過ecx取回this指針.

            第一次調用時,取對象的實例ta的地址到ecx,然后調用TA::callShow
            00411B35  lea         ecx,[ta] 
            00411B38  call        TA::callShow (411019h) 


            第二次調用時,直接把this指針傳遞到ecx,然后調用TA::show
            004114B3  mov         ecx,dword ptr [
            this
            004114B6  call        TA::show (4110EBh) 

            posted on 2012-01-10 16:52 天下 閱讀(661) 評論(0)  編輯 收藏 引用 所屬分類: C/C++

            <2016年6月>
            2930311234
            567891011
            12131415161718
            19202122232425
            262728293012
            3456789

            導航

            統計

            常用鏈接

            留言簿(4)

            隨筆分類(378)

            隨筆檔案(329)

            鏈接

            最新隨筆

            搜索

            最新評論

            精品无码久久久久久久动漫| 99久久中文字幕| 久久久精品国产亚洲成人满18免费网站 | 色偷偷88欧美精品久久久| 一本大道加勒比久久综合| 久久精品国产一区二区三区不卡| 欧美午夜A∨大片久久 | 国产香蕉久久精品综合网| 久久这里只有精品首页| 久久国产高清字幕中文| 亚洲国产成人乱码精品女人久久久不卡 | 国产精品激情综合久久| 日本久久中文字幕| 91久久婷婷国产综合精品青草| 国产精品毛片久久久久久久| 69国产成人综合久久精品| 久久综合视频网站| 久久精品国产清高在天天线| 久久久久亚洲爆乳少妇无| 97久久超碰国产精品旧版| 国产aⅴ激情无码久久| 久久精品国产国产精品四凭| 少妇久久久久久被弄高潮| 久久人人爽人人澡人人高潮AV| 久久91精品久久91综合| 热久久视久久精品18| 欧美综合天天夜夜久久| 久久久久人妻精品一区| 99久久国产综合精品女同图片| 麻豆精品久久精品色综合| 亚洲欧美日韩久久精品第一区| 久久精品亚洲欧美日韩久久| 亚洲AV乱码久久精品蜜桃| 少妇被又大又粗又爽毛片久久黑人 | 久久99精品久久只有精品| 少妇熟女久久综合网色欲| 国内精品久久久久国产盗摄| 久久青青草原国产精品免费| 久久免费国产精品一区二区| 亚洲国产精品久久| 99久久精品国产一区二区三区 |