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

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>
            在线日韩av片| 亚洲欧美变态国产另类| 欧美大秀在线观看| 免费一级欧美片在线观看| 国产精品久久久久久久久久妞妞| 国产欧美精品在线| 亚洲狼人精品一区二区三区| 亚洲免费观看视频| 欧美色视频日本高清在线观看| 99视频在线观看一区三区| 亚洲免费一区二区| 国产精品中文在线| 久久精品国产久精国产爱| 久久婷婷色综合| 亚洲黄页视频免费观看| 欧美日韩精品一区二区三区四区| 99这里只有久久精品视频| 欧美一区二区在线免费播放| 国产一区二区在线免费观看| 久久久久久综合| 日韩视频免费观看高清在线视频| 午夜精品国产| 在线精品国精品国产尤物884a| 欧美精品v日韩精品v国产精品| 亚洲精品国产精品国自产观看| 亚洲人成在线播放| 欧美高清视频在线| 久久综合给合| 亚洲女同精品视频| 国产日本欧美一区二区| 久久精品国产精品亚洲综合| 精品成人在线观看| 免费观看成人www动漫视频| 亚洲黄色天堂| 蜜桃精品久久久久久久免费影院| 一本色道久久综合亚洲91| 国产一区在线免费观看| 欧美精品在线观看91| 美日韩免费视频| 亚洲一级电影| 亚洲性夜色噜噜噜7777| 亚洲国产经典视频| 免费高清在线视频一区·| 欧美一区二区在线视频| 一本色道久久综合亚洲精品高清 | 亚洲国产精品专区久久| 国产精品视频男人的天堂| 欧美成人在线影院| 狂野欧美一区| 久久频这里精品99香蕉| 欧美在线3区| 欧美一区二区三区播放老司机| 中文一区二区| 久久国产婷婷国产香蕉| 久久久高清一区二区三区| 亚洲无线一线二线三线区别av| 欧美成年人视频网站| 老牛嫩草一区二区三区日本 | 日韩午夜电影| 亚洲乱码国产乱码精品精| 亚洲美女中出| 午夜精品久久久久久久久久久久久| 狠狠狠色丁香婷婷综合激情| 久久爱www| 久久久久国产一区二区三区四区 | 久久尤物视频| 亚洲国产二区| 久久九九免费视频| 麻豆精品视频在线| 亚洲精品一区二区三区在线观看| 亚洲国产婷婷| 亚洲理论在线| 老司机一区二区| 国产精自产拍久久久久久蜜| 欧美一区二区三区啪啪| 欧美福利视频网站| 亚洲黄一区二区三区| 亚洲视频在线二区| 午夜日韩视频| 国产精品进线69影院| 黄色日韩在线| 亚洲综合精品自拍| 亚洲黄一区二区三区| 亚洲欧美自拍偷拍| 欧美日韩在线另类| 欧美一区二区三区在线免费观看| 免费不卡中文字幕视频| 国产精品a久久久久久| 最近中文字幕日韩精品| 久久夜色精品国产噜噜av| 夜夜嗨av一区二区三区四季av| 欧美一区日韩一区| 国产一区二区久久久| 亚洲欧美日韩视频二区| 狼人社综合社区| 激情六月婷婷久久| 久久国产精品久久久久久| 亚洲一区二区在线播放| 国产精品久久二区| 亚洲欧美日韩精品在线| 这里只有精品丝袜| 亚洲经典在线| 久久久久久久999精品视频| 国产主播一区| 亚洲精品在线电影| 欧美日韩在线免费| 久久久久久综合网天天| 久久久久久久国产| 亚洲精品在线观看免费| 亚洲黄色在线| 国产日韩精品一区观看| 久久久久久久网站| 欧美岛国在线观看| 亚洲欧美日本在线| 久久黄色影院| 欧美三级午夜理伦三级中文幕| 午夜欧美精品| 99视频日韩| 一区二区三区视频在线看| 国产精品久久久久久久久久久久久 | 欧美视频网站| 亚洲免费中文字幕| 中文国产一区| 亚洲国产你懂的| 久久久久免费观看| 欧美日韩视频不卡| 免费高清在线视频一区·| 久久综合久色欧美综合狠狠| 在线亚洲+欧美+日本专区| 91久久夜色精品国产九色| 国产精品久久福利| 欧美激情视频一区二区三区不卡| 欧美日韩国产三级| 免费成人黄色| 国产三级欧美三级日产三级99| 久久一区精品| 国产综合欧美| 亚洲无毛电影| 亚洲桃色在线一区| 欧美日韩a区| 亚洲电影下载| 国产精品99久久久久久久久久久久 | 国产精品萝li| 亚洲国产一二三| 亚洲国产欧美在线 | 麻豆亚洲精品| 欧美日韩和欧美的一区二区| 亚洲国语精品自产拍在线观看| 一区免费观看| 久久久久九九视频| 欧美黄色网络| 亚洲一区二区三区在线看| 国产精品爱啪在线线免费观看| 亚洲桃色在线一区| 久久久久久久久久久久久9999| 狠狠色综合日日| 欧美剧在线观看| 亚洲一区二区三| 免费观看欧美在线视频的网站| 最新日韩中文字幕| 欧美精品一区在线| 久久精品女人| 99精品国产99久久久久久福利| 国产精品久久毛片a| 久久久久久久尹人综合网亚洲| 亚洲电影免费观看高清| 亚洲欧美综合另类中字| 亚洲激情视频网| 国产精品视频不卡| 欧美经典一区二区| 午夜一区不卡| 一区二区欧美日韩| 亚洲伦伦在线| 国产欧美在线观看| 欧美激情视频在线免费观看 欧美视频免费一 | 亚洲一区二区精品在线| 国产伦精品免费视频 | 亚洲一区免费网站| 欧美日韩一二三区| 亚洲一区二区高清视频| 美女网站久久| 午夜精品久久久久久久99水蜜桃| 国产精品蜜臀在线观看| 欧美精品亚洲| 欧美电影免费观看高清| 麻豆久久婷婷| 欧美丰满高潮xxxx喷水动漫| 久久久噜噜噜久久| 老鸭窝亚洲一区二区三区| 久久久蜜桃一区二区人| 美女福利精品视频| 欧美精品久久久久久久| 欧美人与禽猛交乱配视频| 欧美日韩精品不卡| 国产精品ⅴa在线观看h| 久久久久久网站| 欧美粗暴jizz性欧美20| 欧美高清在线观看| 日韩午夜在线视频| 欧美一区二区三区精品|