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

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的術語來講就是客戶來完成的。這樣帶來了一個棘手的問題,不同的編譯器產生棧的方式不盡相同,那么調用者能否正常的完成清除工作呢?答案是不能?!?br>問一下,為什么答案是不能?自己產生的堆棧為什么不能自己清除?
  回復  更多評論
  

# 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久久久久久| 欧美性猛交xxxx乱大交蜜桃| 亚洲精品视频啊美女在线直播| 麻豆成人小视频| 美脚丝袜一区二区三区在线观看| 夜夜躁日日躁狠狠久久88av| 亚洲日本中文| 午夜欧美精品| 久久狠狠婷婷| 久久中文欧美| 亚洲精选91| 中文无字幕一区二区三区| 日韩手机在线导航| 免费人成网站在线观看欧美高清| 亚洲片在线资源| 亚洲国产欧美一区二区三区久久 | 欧美日韩综合久久| 国产精品美女久久久久久2018| 欧美午夜视频| 国产精品女主播| 国产主播精品| 最新国产の精品合集bt伙计| 亚洲乱亚洲高清| 欧美在线3区| 另类欧美日韩国产在线| 亚洲国产精品久久| 午夜在线一区| 欧美丰满少妇xxxbbb| 国产精品大全| 亚洲欧洲精品一区二区三区不卡 | 欧美/亚洲一区| 亚洲国产日韩美| 性欧美在线看片a免费观看| 久久精品人人做人人爽电影蜜月| 久久久福利视频| 国产精品久久久久久久久久三级| 国产小视频国产精品| 亚洲国产视频一区| 久久精品人人做人人爽电影蜜月| 欧美成人精品福利| 日韩香蕉视频| 理论片一区二区在线| 欧美色欧美亚洲另类七区| 国产区亚洲区欧美区| 国产手机视频一区二区| 宅男精品导航| 快播亚洲色图| 中日韩视频在线观看| 欧美精品1区2区3区| 国产主播精品在线| 亚洲欧美成人一区二区三区| 91久久精品一区| 欧美一区2区视频在线观看| 欧美www在线| 韩国久久久久| 亚洲一区在线视频| 久久久青草婷婷精品综合日韩| 久久综合一区二区三区| 欧美激情一二区| 亚洲在线黄色| 日韩视频一区二区在线观看| 亚洲精品欧美在线| 久久久噜噜噜久久中文字幕色伊伊 | 一区二区三区在线看| 午夜久久美女| 韩国av一区二区三区在线观看| 99综合电影在线视频| 亚洲精品日韩综合观看成人91| 久久九九99| 国产午夜精品在线| 免费人成精品欧美精品| 久久精品久久99精品久久| 国产伦精品一区二区三区视频黑人| 午夜精品理论片| 亚洲在线一区二区三区| 国产精品国产精品国产专区不蜜| 亚洲综合日韩在线| 亚洲色图综合久久| 欧美视频手机在线| 欧美一区二区播放| 午夜精品999| 国产日韩亚洲欧美| 欧美福利电影在线观看| 男女av一区三区二区色多| 亚洲三级电影全部在线观看高清 | 欧美日韩中国免费专区在线看| 亚洲精品国产日韩| 欧美黄色aaaa| 久久成人羞羞网站| 亚洲激情av| 日韩视频在线免费| 国产精品一级| 亚洲国产裸拍裸体视频在线观看乱了中文 | 亚洲男女自偷自拍| 亚洲一区二区三区四区中文 | 欧美一区二区日韩| 亚洲三级色网| 亚洲一卡二卡三卡四卡五卡| 国产精品一区二区三区四区五区| 国产欧美视频在线观看| 欧美制服丝袜第一页| 久久gogo国模裸体人体| 日韩视频―中文字幕| 亚洲小少妇裸体bbw| 国产午夜精品麻豆| 日韩视频一区二区三区| 国产欧美一区二区三区在线看蜜臀 | 国产精品久久久久aaaa| 欧美不卡视频| 国产精品高潮呻吟久久| 久久婷婷丁香| 欧美中文字幕不卡| 亚洲一级黄色| 久久精品综合一区| 中文精品视频一区二区在线观看| 久久精品视频在线| 一区二区高清| 欧美不卡视频一区发布| 国产日产欧产精品推荐色 | 亚洲国产一区二区在线| 久久久亚洲欧洲日产国码αv| 一区二区三区日韩| 午夜在线精品| 欧美一级片久久久久久久| 欧美r片在线| 久久蜜臀精品av| 国产亚洲成年网址在线观看| 99re热精品| 亚洲免费精彩视频| 欧美精品一区二区三区在线看午夜| 久久精品国产99| 欧美天堂亚洲电影院在线播放| 99国产一区二区三精品乱码| 在线观看福利一区| 欧美一区二区三区啪啪| 久久经典综合| 国产精品日本一区二区| 亚洲黄色免费电影| 亚洲国产成人午夜在线一区| 亚洲国产福利在线| 黄色一区三区| 久久久999精品| 欧美母乳在线| 亚洲精品综合精品自拍| 午夜激情久久久| 国产一区二区日韩精品| 久久久久国产精品一区| 欧美成人午夜免费视在线看片| 91久久久在线| 欧美午夜久久久| 欧美一级成年大片在线观看| 老司机凹凸av亚洲导航| 亚洲精品久久在线| 欧美亚洲成人精品| 欧美一区午夜精品| 欧美高清自拍一区| 亚洲五月婷婷| 狠狠色丁香久久婷婷综合_中| 老司机免费视频一区二区| 99在线精品视频在线观看| 久久激情综合网| 日韩视频一区二区三区在线播放免费观看 | 亚洲在线观看免费| 久久蜜桃香蕉精品一区二区三区| 亚洲国产日韩欧美| 欧美日韩喷水| 欧美在线观看网站| 亚洲国产视频一区| 亚洲欧美bt| 亚洲国产精品传媒在线观看| 欧美日本在线观看| 欧美一区二区三区啪啪| 亚洲欧洲在线观看| 欧美中文在线视频| 亚洲精品日韩在线| 国产午夜亚洲精品羞羞网站| 欧美精品videossex性护士| 亚洲欧美日韩成人| 亚洲人成啪啪网站| 久久综合狠狠综合久久综青草| 一本一道久久综合狠狠老精东影业| 国产欧美日韩三级| 欧美精品在线观看一区二区| 欧美一区二区三区啪啪| 亚洲精品欧美激情| 狂野欧美性猛交xxxx巴西| 午夜精品福利电影| 一本色道久久加勒比88综合| 一区二区亚洲欧洲国产日韩| 国产精品丝袜xxxxxxx| 欧美日韩高清在线观看|