它們之間的連接問題主要是因為c c++編繹器對函數(shù)名譯碼的方式不能所引起的,考慮下面兩個函數(shù)
/* c*/
int strlen(char* string)
{
...
}
//c++
int strlen(char* string)
{
...
}
兩個函數(shù)完全一樣。在c在函數(shù)是通過函數(shù)名來識別的,而在C++中,由于存在函數(shù)的重載問題,函數(shù)的識別方式通函數(shù)名,函數(shù)的返回類型,函數(shù)參數(shù)列表三者組合來完成的。因此上面兩個相同的函數(shù),經(jīng)過C,C++編繹后會產(chǎn)生完全不同的名字。所以,如果把一個用c編繹器編繹的目標(biāo)代碼和一個用C++編繹器編繹的目標(biāo)代碼進行連接,就會出現(xiàn)連接失敗的錯誤。
解決的方法是使用extern C,避免C++編繹器按照C++的方式去編繹C函數(shù)
在頭文件中定義:
extern "C" int strlen(char* string)
或
extern "C"
{
int strlen(char* string)
}
當(dāng)C編繹器遇到extern "C"的時候就用傳統(tǒng)的C函數(shù)編譯方法對該函數(shù)進行編譯。由于C編繹器不認(rèn)識extern "C"這個編繹指令,而程序員又希望C,C++程序能共用這個頭文件,因此通常在頭文件中使用_cplusplus宏進行區(qū)分:
#if define _cplusplus
extern "C"{
#endif
int strlen(char* string)
#ifdefine _cplusplus
}
#endif
/* c*/
int strlen(char* string)
{
...
}
//c++
int strlen(char* string)
{
...
}
兩個函數(shù)完全一樣。在c在函數(shù)是通過函數(shù)名來識別的,而在C++中,由于存在函數(shù)的重載問題,函數(shù)的識別方式通函數(shù)名,函數(shù)的返回類型,函數(shù)參數(shù)列表三者組合來完成的。因此上面兩個相同的函數(shù),經(jīng)過C,C++編繹后會產(chǎn)生完全不同的名字。所以,如果把一個用c編繹器編繹的目標(biāo)代碼和一個用C++編繹器編繹的目標(biāo)代碼進行連接,就會出現(xiàn)連接失敗的錯誤。
解決的方法是使用extern C,避免C++編繹器按照C++的方式去編繹C函數(shù)
在頭文件中定義:
extern "C" int strlen(char* string)
或
extern "C"
{
int strlen(char* string)
}
當(dāng)C編繹器遇到extern "C"的時候就用傳統(tǒng)的C函數(shù)編譯方法對該函數(shù)進行編譯。由于C編繹器不認(rèn)識extern "C"這個編繹指令,而程序員又希望C,C++程序能共用這個頭文件,因此通常在頭文件中使用_cplusplus宏進行區(qū)分:
#if define _cplusplus
extern "C"{
#endif
int strlen(char* string)
#ifdefine _cplusplus
}
#endif

