今天一同事在编译类模板时编译不过,其原因是他将模板类的声明和实现分别放在了.h和.cpp中,这里不得不说一下编译器的编译过程 ,(摘抄于c++ primer)当编译器看到模板定义的时候,她不立即产生代码。只有在看到用到模板时,如调用了函数模板,或定义了类模板对象的时候,编译器才产生特定类型的模板实例。
一般而言,当调用函数的时候,编译器只需看到函数的声明。类似的,定义类类型的对象时,类定义必须可用,但成员函数的定义不是必须存在的。因此,应该将类定义和函数声明放在头文件中,而普通函数和类成员函数的定义放在源文中。
模板则不同:要进行实例化,编译器必须能够访问定义模板的源代码。当调用函数模板或类模板的成员函数时,编译器需要函数定义,需要那些通常放在源文件中的代码。
标准c++为编译模板代码定义了两种模型。两种模型中,构造程序的方式很大程度上是相同的,类定义和函数声明放在头文件中,而函数定义和成员定义放在源文件中。两种模型的不同在于编译器怎样使用来自源文件的定义。编译器都支持包含模型。只有一些编译器支持分别编译。
包含编译例子:
模板类头文件List.h 源文件List.cpp
只需在List.h头文件的末尾处加上
#include “list.cpp”