坦率的说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"