彌合C-C 鴻溝:在C 應用程式中公開C 功能
在混合語言環境中工作時,能夠無縫集成編寫的代碼在不同的語言中變得至關重要。當程式碼用 C 和 C 編寫時,這個問題甚至更加明顯,因為 C 的名稱修改帶來了挑戰。
考慮從 C 呼叫 C 函數的需要。在 C 域中, extern " C" 關鍵字允許我們以 C 相容的方式公開函數,從而提供在 C 應用程式中使用 C 函數的直接方法。然而,相反的情況,即 C 程式碼必須呼叫 C 函數,會出現一組不同的障礙。
克服名稱損壞
主要障礙來自名稱損壞C 使用的約定。這些約定使得 C 代碼很難直接引用 C 符號,從而導致無法解決的符號錯誤。
為了克服這個問題,一個常見的方法是建立一個包裝 C 功能的 C API。此 API 由純 C 程式碼組成,無需使用 C 類或物件即可公開所需的功能。透過遵循物件導向的風格,API 可以為 C 程式碼提供熟悉的互動介面。
範例實作
以下是C API 方法實際實作:
// *.h file #ifdef __cplusplus #define EXTERNC extern "C" #else #define EXTERNC #endif typedef void* mylibrary_mytype_t; EXTERNC mylibrary_mytype_t mylibrary_mytype_init(); EXTERNC void mylibrary_mytype_destroy(mylibrary_mytype_t mytype); EXTERNC void mylibrary_mytype_doit(mylibrary_mytype_t self, int param); #undef EXTERNC
// *.cpp file mylibrary_mytype_t mylibrary_mytype_init() { return new MyType; } void mylibrary_mytype_destroy(mylibrary_mytype_t untyped_ptr) { MyType* typed_ptr = static_cast<MyType*>(untyped_ptr); delete typed_ptr; } void mylibrary_mytype_doit(mylibrary_mytype_t untyped_self, int param) { MyType* typed_self = static_cast<MyType*>(untyped_self); typed_self->doIt(param); }
在這個例子中,C API 提供了一個例子群組函數來創建,銷毀並操作MyType 類型的對象,隱藏幕後C 類別和物件的實作細節。
以上是C 程式碼如何存取 C 功能?的詳細內容。更多資訊請關注PHP中文網其他相關文章!