研究一個開源算法庫,采用C++模板編程,所有函數實現都放在了頭文件中,現在把模板去掉,鏈接時發生沖突,具體原因如下:
因為多個源文件包含了含有函數定義的頭文件,在編譯的時候,每個源文件都會包含一份函數定義,在鏈接時編譯器不知道需要連接哪一份函數定義。
解決方法有三個:
1. inline關鍵字
可以用關鍵字inline修飾函數定義,例如:
inline int add(int x, int y) { return x + y; }
使用inline關鍵字,編譯器會在調用此函數的地方把函數的目標代碼直接插入,像宏一樣被就地展開了。
另外使用inline關鍵字會有兩個缺點:代碼的體積變大了;inline不算C語言的關鍵字,以后代碼移植可能會出現問題。
2. static關鍵字
可以用關鍵字static修飾函數定義,例如:
static int add(int x, int y)
{
return x + y;
}
使用static關鍵字,所有包含此頭文件的源文件中都會存在此函數的一份副本,代碼也有一定程度的膨脹,但好就好在互相不沖突,因為 static 關鍵字保證了該函數的可見度為單個源文件之內。
3. 通過類的成員函數實現
實現方式如下:
#define Add(i,j) Math_Add::add(i,j) class Math_Add { public: static int add(int x, int y) { return x + y; } }
在使用的時候,調用Add(i, j)即可實現。
以上是三種把函數實現放在頭文件中的方法,但是最好還是不要這樣做,還是將函數聲明和實現分開比較好。
參考文章:http://blog.csdn.net/freeboy1015/article/details/8075849