坦率的說CodeBlocks是一款不錯的跨平台編譯器,一般編寫C/C++都是使用它,但最近在編寫C++模板文件時,發現它對模板的支持並不是很好。具體表現在模板的定義與聲明分開的問題上。
一般編寫C/C++程序時,我們都提倡將頭文件與實現文件分開。普通的函數文件與普通的類文件在CodeBlocks中實現.h文件和.cpp文件的分離沒有任何問題。但是若要實現模板的.h文件和.cpp文件的分離則存在較大的問題,無論是函數模板還是類模板。
眾所周知模板的編譯模型有兩種,包含編譯模型與分離編譯模型,但我發現CodeBlocks對這兩種編譯模型並不支持。
1.包含編譯模型:
以下是一個cmp函數文件的.h和.cpp文件
//cmp header file
#ifndef CMP_H_INCLUDED
#define CMP_H_INCLUDED
template<typename T> T cmp(T number1, T number2);
#include "cmp.cpp" //將cmp.cpp包含進.h文件之中,此為包含編譯模型
#endif // CMP_H_INCLUDED
//cmp source file
#include "cmp.h"
template<typename T>
T cmp(T number1, T number2)
{
return number1 - number2;
}
//main.cpp
#include <iostream>
#include "cmp.h"
using namespace std;
int main()
{
cout << cmp(1, 10) << endl;
return 0;
}
但程序編譯時會出現以下錯誤:

其意思就是:
在cmp.cpp文件中template<typename T> T cmp(T, T)出現重定義
在這之前template<typename T> T cmp(T, T)已經被定義
2.分離編譯模型
//cmp header file
#ifndef CMP_H_INCLUDED
#define CMP_H_INCLUDED
template<typename T> T cmp(T number1, T number2);
#endif // CMP_H_INCLUDED
//cmp source file
#include "cmp.h"
export template<typename T> //此句是實現分離編譯模型的基礎
T cmp(T number1, T number2)
{
return number1 - number2;
}
//main.cpp
#include <iostream>
#include "cmp.h"
using namespace std;
int main()
{
cout << cmp(1, 10) << endl;
return 0;
}
但程序在編譯時會出現以下錯誤:

意思如下:
export 不能實現,將被忽略
沒有定義int cmp<int>(int, int),在函數實例化時,沒有找到模板的實現文件
但是以上的兩種不支持並不影響模板在CodeBlocks中的使用,因為以下兩種方式編寫模板文件在CodeBlocks均可以正常使用。
1.只為模板文件建立一個.h文件,將實現代碼全部放在.h文件之中。
2.將.h文件和.cpp文件分開,在使用時這樣使用
#include "cmp.h"
#include "cmp.cpp"
