DLL入門淺析(4)——從DLL中導出類
DLL頭文件:























DLL實現文件:

































應用程序調用DLL














大家可能發現了,上面我沒有使用模塊定義文件(.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文件聲明導出類和顯式鏈接,但是可以用另外一種取巧的方式。
friend DLLClass* CreatDLLClass();
然后聲明CreatDLLClass()為導出函數,通過調用該函數返回一個DLLClass類的對象,同樣達到了導出類的目的。
這樣,就可以用顯式鏈接來調用CreatDLLClass(),從而得到類對象了。
posted on 2009-07-20 20:50 Saga 閱讀(50504) 評論(8) 編輯 收藏 引用 所屬分類: Windows