關于extern "C"
用C++進行開發,尤其涉及到開發dll模塊時,我們發現頭文件中經常定義為
#ifdef __cplusplus
extern "C"


{
#endif




#ifdef __cplusplus
};
#endif






這樣做有什么好處呢?
我們知道,C++會對函數內部命名,比如說void f(int x,int y),如果通過C編譯器編譯,則生成的函數名字為f,如果通過C++編譯器編譯,則內部函數名會改編,例如 @@f@_int@int...(只是便于舉例),所以,如果用c++編譯的dll,在C中無法調用,因為找不到對應的函數。
為了解決該問題,于是引入extern “C”,這樣C++編譯器在碰到extern “C”聲明的函數時,會采用C編譯方式編譯。這樣編譯后的dll,無論在C中還是C++中均可以使用。不過因為C不對函數名字進行改編,所以無法支持函數重載。此外,如果需要導出類,則也沒法聲明為extern "C",因為C語言中不支持類,導出類的時候extern “C” 無意義。
說到這,提一下后綴名如何影響編譯,如果后綴名為cpp,在不加extern “C”的情況下采取c++編譯方式,名字會改編,如果后綴名為c,則采取c編譯方式。
經常有人問,C++調用C文件時,為什么老是編譯和連接出錯?這個問題也在于編譯方式不同,函數名字不同,找不到對應的函數,所以出錯了。所以,C++中要引入c編譯的模塊,記得在對應的頭文件中加入上述代碼就可以了。




















我們知道,C++會對函數內部命名,比如說void f(int x,int y),如果通過C編譯器編譯,則生成的函數名字為f,如果通過C++編譯器編譯,則內部函數名會改編,例如 @@f@_int@int...(只是便于舉例),所以,如果用c++編譯的dll,在C中無法調用,因為找不到對應的函數。
為了解決該問題,于是引入extern “C”,這樣C++編譯器在碰到extern “C”聲明的函數時,會采用C編譯方式編譯。這樣編譯后的dll,無論在C中還是C++中均可以使用。不過因為C不對函數名字進行改編,所以無法支持函數重載。此外,如果需要導出類,則也沒法聲明為extern "C",因為C語言中不支持類,導出類的時候extern “C” 無意義。
說到這,提一下后綴名如何影響編譯,如果后綴名為cpp,在不加extern “C”的情況下采取c++編譯方式,名字會改編,如果后綴名為c,則采取c編譯方式。
經常有人問,C++調用C文件時,為什么老是編譯和連接出錯?這個問題也在于編譯方式不同,函數名字不同,找不到對應的函數,所以出錯了。所以,C++中要引入c編譯的模塊,記得在對應的頭文件中加入上述代碼就可以了。
posted on 2009-04-12 01:18 五味雜陳 閱讀(322) 評論(0) 編輯 收藏 引用 所屬分類: C++