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<string, MMSINFO>::iterator it;
// ...
}