青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

ivy-jie

progress ...

C++博客 首頁 新隨筆 聯系 聚合 管理
  9 Posts :: 41 Stories :: 6 Comments :: 0 Trackbacks

(1) _stdcall調用
_stdcall是Pascal程序的缺省調用方式,參數采用從右到左的壓棧方式,被調函數自身在返回前清空堆棧。
WIN32 Api都采用_stdcall調用方式,這樣的宏定義說明了問題:

  #define WINAPI _stdcall

  按C編譯方式,_stdcall調用約定在輸出函數名前面加下劃線,后面加“@”符號和參數的字節數,形如_functionname@number

(2) _cdecl調用
_cdecl是C/C++的缺省調用方式,參數采用從右到左的壓棧方式,傳送參數的內存棧由調用者維護。_cedcl約定的函數只能被C/C++調用,每一個調用它的函數都包含清空堆棧的代碼,所以產生的可執行文件大小會比調用_stdcall函數的大。

  由于_cdecl調用方式的參數內存棧由調用者維護,所以變長參數的函數能(也只能)使用這種調用約定。關于C/C++中變長參數(…)的問題,筆者將另文詳述。

  由于Visual C++默認采用_cdecl 調用方式,所以VC中中調用DLL時,用戶應使用_stdcall調用約定。
按C編譯方式,_cdecl調用約定僅在輸出函數名前面加下劃線,形如_functionname。

  (3) _fastcall調用
_fastcall調用較快,它通過CPU內部寄存器傳遞參數。

  按C編譯方式,_fastcall調用約定在輸出函數名前面加“@”符號,后面加“@”符號和參數的字節數,形如@functionname@number。

------------------------------------------------------------------------------------------------------------

_cdecl是C和C++程序的缺省調用方式。每一個調用它的函數都包含清空堆棧的代碼,所以產生的可執行文件大小會比調用_stdcall函數的大。函數采用從右到左的壓棧方式。VC將函數編譯后會在函數名前面加上下劃線前綴。_stdcall是Pascal程序的缺省調用方式,通常用于Win32 Api中,函數采用從右到左的壓棧方式,自己在退出時清空堆棧。VC將函數編譯后會在函數名前面加上下劃線前綴,在函數名后加上"@"和參數的字節數。_fastcall方式的函數采用寄存器傳遞參數,VC將函數編譯后會在函數名前面加上"@"前綴,在函數名后加上"@"和參數的字節數。這兩個關鍵字看起來似乎很少和我們打交道,但是看了下面的定義(來自windef.h),你一定會覺得驚訝:   
#define CALLBACK     __stdcall  
#define WINAPI       __stdcall   
#define WINAPIV      __cdecl   
#define APIENTRY     WINAPI    
#define APIPRIVATE   __stdcall   
#define PASCAL       __stdcall    
#define cdecl _cdecl   
#ifndef CDECL    
#define CDECL _cdecl    
幾乎我們寫的每一個WINDOWS API函數都是__stdcall類型的,為什么??

首先,我們談一下兩者之間的區別:      
WINDOWS的函數調用時需要用到棧(STACK,一種先入后出的存儲結構)。當函數調用完成后,棧需要清除,這里就是問題的關鍵,如何清除??      
如果我們的函數使用了_cdecl,那么棧的清除工作是由調用者,用COM的術語來講就是客戶來完成的。這樣帶來了一個棘手的問題,不同的編譯器產生棧的方式不盡相同,那么調用者能否正常的完成清除工作呢?答案是不能。      
如果使用__stdcall,上面的問題就解決了,函數自己解決清除工作。所以,在跨(開發)平臺的調用中,我們都使用__stdcall(雖然有時是以WINAPI的樣子出現)。       那么為什么還需要_cdecl呢?當我們遇到這樣的函數如fprintf()它的參數是可變的,不定長的,被調用者事先無法知道參數的長度,事后的清除工作也無法正常的進行,因此,這種情況我們只能使用_cdecl。       到這里我們有一個結論,如果你的程序中沒有涉及可變參數,最好使用__stdcall關鍵字    

posted on 2009-05-23 18:38 ivy-jie 閱讀(2275) 評論(5)  編輯 收藏 引用

Feedback

# re: _stdcall和_cdec區別 2012-05-29 10:57 任騰
“如果我們的函數使用了_cdecl,那么棧的清除工作是由調用者,用COM的術語來講就是客戶來完成的。這樣帶來了一個棘手的問題,不同的編譯器產生棧的方式不盡相同,那么調用者能否正常的完成清除工作呢?答案是不能。”
問一下,為什么答案是不能?自己產生的堆棧為什么不能自己清除?
  回復  更多評論
  

# re: _stdcall和_cdec區別 2012-06-18 21:12 Honwhy
使用者在另外一個線程中。@任騰
  回復  更多評論
  

# re: _stdcall和_cdec區別 2012-08-22 18:43 zwxhbxf
當我們遇到這樣的函數如fprintf()它的參數是可變的,不定長的,被調用者事先無法知道參數的長度,事后的清除工作也無法正常的進行,因此,這種情況我們只能使用_cdecl。  回復  更多評論
  

# re: _stdcall和_cdec區別 2012-08-22 18:48 zwxhbxf
清除工作也無法正常的進行不是一種缺陷嗎?難得不管它?  回復  更多評論
  

# re: _stdcall和_cdec區別 2012-09-03 13:34 wd
@任騰因為堆棧指針式由調用者push而減小 所以 只有調用才知道壓入了多少數據%esp要addl多少才能返回之前的調用狀態
  回復  更多評論
  


只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            伊人久久久大香线蕉综合直播 | 日韩一级大片| 国产精品国产精品国产专区不蜜| 亚洲欧美制服中文字幕| 亚洲国产精品福利| 久久精品99国产精品酒店日本| 一本大道久久精品懂色aⅴ| 国产精品一区亚洲| 国产精品老女人精品视频| 欧美激情综合五月色丁香小说| 久久天堂精品| 久久久久久久综合| 久久激情一区| 日韩香蕉视频| 在线中文字幕不卡| 亚洲永久网站| 欧美在线综合| 久久久www免费人成黑人精品 | 欧美一区日本一区韩国一区| 午夜精品久久久久影视| 亚洲欧美日韩国产综合精品二区| 黄色成人在线观看| 欧美激情视频网站| 欧美日韩国产bt| 国产精品国产三级国产aⅴ无密码| 欧美日韩午夜激情| 国产精品草草| 国产偷国产偷亚洲高清97cao| 国产日韩欧美在线观看| 国产日韩欧美一区二区| 国内一区二区三区在线视频| 伊人精品在线| 99天天综合性| 久久精品观看| 亚洲国产精品免费| 欧美激情精品久久久久久| 另类图片国产| 亚洲伦伦在线| 欧美一区二区视频97| 免费人成网站在线观看欧美高清| 欧美精品综合| 国产午夜精品一区理论片飘花 | 99精品免费网| 亚洲欧美国产毛片在线| 久久久另类综合| 9人人澡人人爽人人精品| 亚洲免费视频中文字幕| 噜噜噜久久亚洲精品国产品小说| 欧美国产专区| 亚洲女人小视频在线观看| 久久综合中文字幕| 国产精品男人爽免费视频1| 狠狠色狠狠色综合日日tαg| 一区二区精品| 亚洲在线播放| 亚洲第一网站| 久久精品视频免费播放| 欧美亚日韩国产aⅴ精品中极品| 激情综合色丁香一区二区| 一本色道久久综合精品竹菊| 久久久人成影片一区二区三区观看 | 欧美日韩美女在线| 欧美精品免费观看二区| 国产综合亚洲精品一区二| 在线亚洲精品| 欧美不卡在线| 欧美一区二区免费| 国产精品国产亚洲精品看不卡15 | 欧美日韩爆操| 在线免费观看一区二区三区| 亚洲一区二区三区在线播放| 美女91精品| 亚洲欧美高清| 国产精品国产三级国产a| 永久域名在线精品| 欧美尤物一区| 亚洲欧美国产日韩天堂区| 久久久人成影片一区二区三区| 国产精品日韩精品欧美精品| 亚洲一级片在线看| 99精品国产热久久91蜜凸| 欧美激情精品| 夜夜爽av福利精品导航 | 亚洲精品一区二区三区av| 久久久久**毛片大全| 亚洲一区二区三区免费视频| 欧美亚一区二区| 亚洲少妇自拍| 欧美激情一二三区| 蜜臀久久99精品久久久画质超高清| 久久不射网站| 国外成人在线视频| 久久久蜜桃精品| 久久夜色撩人精品| 亚洲人在线视频| 91久久夜色精品国产九色| 欧美久久影院| 影音先锋成人资源站| 亚洲一区精品视频| 亚洲一区二区在线免费观看| 国产欧美丝祙| 久久欧美中文字幕| 久久久久一区二区| 亚洲精品日韩一| 99精品热视频只有精品10| 国产精品久久久久久户外露出 | 亚洲特色特黄| 亚洲欧美电影在线观看| 伊人久久婷婷| 亚洲乱码久久| 国内精品国产成人| 亚洲高清电影| 国产九九视频一区二区三区| 久久久99免费视频| 欧美aaaaaaaa牛牛影院| 中文日韩在线| 久久国产精品毛片| 日韩一级黄色大片| 亚洲一区视频在线观看视频| 黑人极品videos精品欧美裸| 91久久精品国产91性色tv| 国产精品福利网| 欧美+日本+国产+在线a∨观看| 欧美日韩国产黄| 久久免费99精品久久久久久| 欧美日本国产一区| 久久婷婷国产麻豆91天堂| 欧美国产日韩亚洲一区| 久久国产免费| 欧美日韩成人一区| 久久久噜噜噜| 国产精品成人一区二区网站软件| 久久躁日日躁aaaaxxxx| 久久精品国语| 性伦欧美刺激片在线观看| 美日韩精品免费| 欧美亚洲自偷自偷| 欧美成人精品h版在线观看| 欧美在线免费一级片| 欧美日韩国产综合一区二区| 免费欧美视频| 国产精品xnxxcom| 久久久久国色av免费看影院 | 黄色影院成人| 亚洲一区二区三区精品动漫| 亚洲一区二区三区激情| 国产精品高潮久久| 中文欧美字幕免费| 国产亚洲激情| 久久久精品动漫| 欧美福利网址| 一区二区日本视频| 国产精品夜夜夜一区二区三区尤| 亚洲欧美日韩国产成人精品影院| 久久久噜久噜久久综合| 亚洲大胆人体视频| 免费在线视频一区| 日韩视频免费在线| 欧美一区午夜精品| 亚洲第一中文字幕| 欧美激情成人在线| 中文无字幕一区二区三区| 欧美一区二区成人| 精品91视频| 欧美片在线观看| 亚洲欧美国产日韩中文字幕 | 在线亚洲电影| 久久久av水蜜桃| 亚洲美女视频在线观看| 国产精品久久看| 久久久久99| 亚洲毛片网站| 久久精品国产第一区二区三区最新章节| 激情六月综合| 欧美日韩成人一区二区| 欧美一二三区在线观看| 亚洲国产精品久久久久秋霞不卡| 午夜精品国产更新| 亚洲大片在线| 欧美性jizz18性欧美| 久久久久久久波多野高潮日日| 亚洲精品国产无天堂网2021| 欧美综合第一页| 亚洲私人黄色宅男| 亚洲电影天堂av| 国产精品一区二区在线观看网站| 老牛影视一区二区三区| 亚洲欧美国产高清va在线播| 亚洲国产精品黑人久久久 | 亚洲精品韩国| 欧美ab在线视频| 性欧美1819sex性高清| 一区二区久久久久久| 亚洲福利在线观看| 国产日韩欧美一区二区| 国产精品久久久| 欧美日韩亚洲激情| 欧美不卡视频| 欧美成人网在线| 久久久一区二区三区|