如果使用C語言編寫的DLL,希望從中匯出函式給C或C++的模組訪問,則應使用 __cplusplus 前處理器巨集確定正在編譯的語言。如果是從C++語言模組使用,則用C連結宣告這些函式。如果使用此技術併為DLL提供標頭檔案,則這些函式可以原封不動地由C和C++模組使用。下面是小編為大家帶來的C與C++之間相互呼叫的例項方法,歡迎閱讀。
1、匯出C函式以用於C或C++的專案
如果使用C語言編寫的DLL,希望從中匯出函式給C或C++的模組訪問,則應使用 __cplusplus 前處理器巨集確定正在編譯的語言。如果是從C++語言模組使用,則用C連結宣告這些函式。如果使用此技術併為DLL提供標頭檔案,則這些函式可以原封不動地由C和C++模組使用。
以下程式碼演示可由 C 和 C++ 客戶端應用程式使用的標頭檔案:
程式碼如下:
// MyCFuncs.h
#ifdef __cplusplus
extern "C" { // only need to export C interface if
// used by C++ source code
#endif
__declspec( dllimport ) void MyCFunc();
__declspec( dllimport ) void AnotherCFunc();
#ifdef __cplusplus
}
#endif
MyCFunc()和AnotherCFunc()為C語言DLL的匯出函式。
如果需要將C函式連結到C++可執行檔案,並且函式宣告標頭檔案沒有使用上面的技術,則在C++原始檔中新增下列內容以防止編譯器修飾C函式名:
程式碼如下:
extern "C"
{
#include "MyCHeader.h"
}
該程式碼告訴編譯器"MyCHeader.h"是C寫的.,不要修飾標頭檔案中的C函式名,否則連線的時候會找不到。
2、匯出 C++ 函式以用於C語言專案
如果在用C++編寫的DLL中有希望從C語言模組訪問的函式,應使用C連結而不是C++連結來宣告這些函式。除非另外指定,C++編譯器使用C++型別安全命名約定(也稱作名稱修飾)和C++呼叫約定(使用此呼叫約定從C呼叫會很困難)。
若要指定 C 連結,請在DLL中為函式宣告指定 extern "C"。例如:
程式碼如下:
extern "C" __declspec( dllexport ) int MyFunc(long parm1);
在C語言的函式中是無法直接呼叫C++程式碼的,如果要呼叫,可以做一個wrapper,例如call_Lib_CPPFunction,它的宣告和實現如下:
程式碼如下:
// wrapper function
extern "C" void call_Lib_CPPFunction(Lib* p, DataAttribute* dataAttribute)
{
p->daFun(dataAttribute);
}
// daFun才是我們C++程式碼的實現
void Lib::daFun(DataAttribute* dataAttribute)
{
map::iterator it;
// ...
}