CodeBlocks对C++模板的支持

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

但程序编译时会出现以下错误:

CodeBlocks对C++模板的支持_第1张图片

其意思就是:

在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;
}

但程序在编译时会出现以下错误:

CodeBlocks对C++模板的支持_第2张图片

 

意思如下:

export 不能实现,将被忽略

没有定义int cmp<int>(int, int),在函数实例化时,没有找到模板的实现文件

但是以上的两种不支持并不影响模板在CodeBlocks中的使用,因为以下两种方式编写模板文件在CodeBlocks均可以正常使用。

1.只为模板文件建立一个.h文件,将实现代码全部放在.h文件之中。

2.将.h文件和.cpp文件分开,在使用时这样使用

   #include "cmp.h"

   #include "cmp.cpp"

你可能感兴趣的:(codeblocks)