在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中文網其他相關文章!