typedef bool (__stdcall *T_KJ_PLAYM4_OpenFile)(long, LPCSTR);
HINSTANCE h1 = LoadLibrary(_T("KJ_dll\\kjcodec.dll"));
T_KJ_PLAYM4_OpenFile My_KJ_PLAYM4_OpenFile;
My_KJ_PLAYM4_OpenFile = (T_KJ_PLAYM4_OpenFile)GetProcAddress(h1, "_KJ_PLAYM4_OpenFile@8");
通过GetProcAddress导出时要Dependency看DLL的导出函数的名字,这样才能导出函数成功。
文章地址:http://blog.csdn.net/conanlrj/article/details/5797549
当你使用extern "C"的情况下:
__stdcall会使导出函数名字前面加一个下划线,后面加一个@再加上参数的字节数,比如_Fun@4就是4个字节
__fastcall类似__stdcall,不过前面没有下划线,_fastcall应该前面还有一个@,比如@LoadaDir@4
__cdecl则是前面仅仅有一个下划线
如果不用extern "C"话则使用C++命名机制,涉及到C++ Name Mangling,比较复杂,编译器之间也不太一样。
另外,__declspec(dllexport)仅会对__cdecl进行处理,去掉前面的下划线(对于一般全局函数来说缺省就是__cdecl),而对于其他两种不会处理。