天行健,君子以自強不息; 地勢坤,君子以厚德載物
大家可能發現了,上面我沒有使用模塊定義文件(.def)聲明導出類也沒有用顯式鏈接導入DLL。 用Depends查看前面編譯出來的DLL文件,會發現里面導出了很奇怪的symbol,這是因為C++編譯器在編譯時會對symbol進行修飾。這是我從別人那兒轉來的截圖。
網上找了下,發現了C++編譯時函數名的修飾約定規則
__stdcall調用約定:
1、以"?"標識函數名的開始,后跟函數名;2、函數名后面以"@@YG"標識參數表的開始,后跟參數表;3、參數表以代號表示:
X——void,D——char,E——unsigned char,F——short,H——int,I——unsigned int,J——long,K——unsigned long,M——float,N——double,_N——bool,....
PA——表示指針,后面的代號表明指針類型,如果相同類型的指針連續出現,以"0"代替,一個"0"代表一次重復;4、參數表的第一項為該函數的返回值類型,其后依次為參數的數據類型,指針標識在其所指數據類型前; 5、參數表后以"@Z"標識整個名字的結束,如果該函數無參數,則以"Z"標識結束。 其格式為"?functionname@@YG*****@Z"或?functionname@@YG*XZ,
int Test1(char *var1,unsigned long)-----“?Test1@@YGHPADK@Z” void Test2() -----“?Test2@@YGXXZ”
__cdecl調用約定: 規則同上面的_stdcall調用約定,只是參數表的開始標識由上面的"@@YG"變為"@@YA"。
__fastcall調用約定: 規則同上面的_stdcall調用約定,只是參數表的開始標識由上面的"@@YG"變為"@@YI"。VC++對函數的省缺聲明是"__cedcl",將只能被C/C++調用。雖然因為C++編譯器對symbol進行修飾的原因不能直接用def文件聲明導出類和顯式鏈接,但是可以用另外一種取巧的方式。
posted on 2009-07-20 20:50 Saga 閱讀(50503) 評論(8) 編輯 收藏 引用 所屬分類: Windows
你應該分析下導出類有什么要注意的事項以及優缺點等,會比較有意義。 回復 更多評論
辛苦了 回復 更多評論
@風 恩,謝謝你的提議。 回復 更多評論
不錯哦 回復 更多評論
如果用*.def文件直接對:變量、類,這兩種類型進行導出生命啊? 回復 更多評論
謝謝 最近正在學習 回復 更多評論
“DLL_SAMPLE_API class DLLClass” ? 應該是class DLL_SAMPLE_API DLLClass 回復 更多評論
謝謝樓主分享。 回復 更多評論