首頁  >  文章  >  後端開發  >  名稱混淆和extern "C"在C++中

名稱混淆和extern "C"在C++中

WBOY
WBOY轉載
2023-08-29 10:21:111297瀏覽

名称混淆和extern "C"在C++中

在C 中我們可以使用函數重載特性。利用這個特性,我們可以創建同名的函數。唯一的區別是參數的類型和參數的數量。這裡不考慮返回類型。現在的問題是,C 如何區分目標程式碼中的重載函數?

在目標程式碼中,它透過添加有關參數的資訊來更改名稱。這裡應用的技術稱為名稱修改。 C 沒有標準化的名稱重整技術。因此不同的編譯器使用不同的技術。

下面是名稱重整的範例。重載函數被命名為 func(),還有另一個函數 my_function()。

範例

int func(int x) {
   return x*x;
}
double func(double x) {
   return x*x;
}
void my_function(void) {
   int x = func(2); //integer
   double y = func(2.58); //double
}

某些C 編譯器會像下面這樣更改它-

範例

int __func_i(int x) {
   return x*x;
}
double __func_d(double x) {
   return x*x;
}
void __my_function_v(void) {
   int x = __func_i(2); //integer
   double y = __func_d(2.58); //double
}

C不支援函數重載,所以當我們在C 中連結C代碼時,我們必須確保符號的名稱沒有改變。以下 C 程式碼將產生錯誤。

範例

int printf(const char *format,...);
main() {
   printf("Hello World");
}

輸出

undefined reference to `printf(char const*, ...)'
ld returned 1 exit status

產生此問題的原因是編譯器變更了 printf() 的名稱。並且它沒有找到更新後的 printf() 函數的定義。為了解決這個問題,我們必須在C 中使用extern「C」。當此區塊內使用某些程式碼時,C 編譯器會確保函數名稱未被破壞。所以這個名字不會改變。所以上面的程式碼就會這樣來解決這個問題。

範例

extern "C" {
   int printf(const char *format,...);
}
main() {
   printf("Hello World");
}

輸出

Hello World

注意:這些程式碼區塊可能會在不同的編譯器中產生不同的結果。

以上是名稱混淆和extern "C"在C++中的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:tutorialspoint.com。如有侵權,請聯絡admin@php.cn刪除