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

            happem

            C基礎下的函數(shù)調用技巧

            與函數(shù)堆棧使用密切相關的就是函數(shù)調用規(guī)范,即調用約定(Calling Convenion)。函數(shù)調用規(guī)范決定了函數(shù)調用的實參壓棧、退棧及堆棧釋放的方式以及函數(shù)名改編的方案,windows環(huán)境下常用的調用規(guī)范有:

            1)      _cedcl:這是C++/C函數(shù)的默認調用規(guī)范,參數(shù)從右向左傳遞壓入堆棧,由調用函數(shù)復雜堆棧的清退,因此這種方式利于傳遞個數(shù)可變的參數(shù)給被調用函數(shù)。如printf()就是這樣的函數(shù)。

            2)      _stdcall:這是Win API函數(shù)使用的調用規(guī)范,參數(shù)從右向左依次傳遞并壓入堆棧,由被調用函數(shù)復雜堆棧的清退。該規(guī)范生成的函數(shù)代碼比_cdecl更小,但當函數(shù)有可變個數(shù)的參數(shù)時會轉為_cdecl規(guī)范。在Windows中,宏WINAPI、CALLBACK都定義為_stdcall。

            3)      _thiscall:是C++非靜態(tài)成員函數(shù)的默認調用規(guī)范,不能使用個數(shù)可變的參數(shù)。當調用非靜態(tài)成員函數(shù)的時候,this指針直接保存在ECX寄存器中而壓入函數(shù)堆棧,其他方面與_stdcall相同。

            4)      _fastcall:該規(guī)范所修飾的函數(shù)的實參將被直接傳遞到CPU寄存器中而不是內存堆棧中,堆棧清退由被調用函數(shù)負責,該規(guī)范不能用于成員函數(shù)。

            函數(shù)必須制定的一個調用規(guī)范,特別是在模塊之間的邏輯接口中,每個函數(shù)原型的調用規(guī)范必須與其實的調用規(guī)范保持一致,否則會出現(xiàn)編譯連接錯誤。如果你調用了在某個DLL中實現(xiàn)的COM對象的方法,而這些方法在創(chuàng)建時卻沒顯式地制定調用規(guī)范,那么它們會使用環(huán)境默認的調用規(guī)范,雖然你的程序可以通過編譯和連接,但是在運行時就可能導致程序崩潰。

            所以,凡是接口函數(shù)都必須顯式地制定其調用規(guī)范,除非接口函數(shù)是類的非靜態(tài)成員函數(shù),如果不顯式制定調用規(guī)范,類的靜態(tài)成員函數(shù)和全局函數(shù)將采用C++/C默認的函數(shù)調用規(guī)范或者由工程設置指定的調用規(guī)范,因此最好也為靜態(tài)成員函數(shù)顯式地指定調用規(guī)范。

            注意:類的靜態(tài)成員函數(shù)的默認調用規(guī)范不是thiscall,類的友元函數(shù)的調用也不是thiscall,它們都是由函數(shù)本身指定或者由工程設定的。COM接口的方法都指定_stdcall調用規(guī)范,而我們自己開發(fā)COM對象及接口時也可以指定其他的調用規(guī)范。

             

            一定要知道C基礎的基本概念:

             

            認識函數(shù)堆棧:http://www.lirenedu.org/index.php?ack=xinwen&id=1026

            基于C語言基礎概念:http://www.lirenedu.org/index.php?ack=xinwen&id=1024

            操作系統(tǒng)幾個基本要點:http://www.lirenedu.org/index.php?ack=xinwen&id=1029

            posted on 2012-09-03 10:55 happem 閱讀(250) 評論(0)  編輯 收藏 引用

            狠狠色婷婷久久一区二区 | 国产激情久久久久影院| 国产福利电影一区二区三区久久老子无码午夜伦不 | 久久国产成人亚洲精品影院| 亚洲综合熟女久久久30p| 久久国产色AV免费看| 一本久久a久久精品亚洲| 97久久综合精品久久久综合| 久久精品国产亚洲av日韩| 国产日韩欧美久久| 嫩草伊人久久精品少妇AV| 亚洲国产另类久久久精品黑人| 亚洲精品成人网久久久久久| 久久久久亚洲AV成人网人人网站| 久久99国产精品久久99| 久久久久无码精品国产| 精品欧美一区二区三区久久久 | 国内精品九九久久久精品| 亚洲精品乱码久久久久久 | 99久久99久久精品国产片果冻| 久久综合综合久久狠狠狠97色88| 97热久久免费频精品99| 久久99热这里只有精品66| 少妇人妻综合久久中文字幕| 成人国内精品久久久久影院VR| 久久精品黄AA片一区二区三区 | 伊人热人久久中文字幕| 狠狠综合久久综合中文88 | 国产激情久久久久影院小草| 国产成人久久AV免费| 人妻少妇久久中文字幕一区二区| 欧美久久久久久午夜精品| 99久久国产主播综合精品| avtt天堂网久久精品| 国产精品99久久免费观看| 久久国产欧美日韩精品 | 久久青青色综合| 99精品国产在热久久无毒不卡 | 亚洲日韩欧美一区久久久久我| 久久一区二区三区免费| 欧美色综合久久久久久|