首先呢,先了解一下什么是c++分离式编译。就比如说,我们要写一个非模板类A,会把类的声明放在test.h文件里面,再把该类的定义(即对类的实现)放在test.cpp中,并再test.cpp开头增加语句#include"test.h"这种方式。最后,再main.cpp中再对类对象实例化。这是c++程序员比较乐意接受的一种类编写方式,这也符合一般头文件规则:“不要在分配存储空间前放置任何东西”,这条规则是为了防止在连接时的多重定义错误。
为什么C++编译器不能支持对模板的分离式编译 ???
首先,C++标准中提到,一个编译单元[translation unit]是指一个.cpp文件以及它所include的所有.h文件,.h文件里的代码将会被扩展到包含它的.cpp文件里,然后编译器编译该.cpp文件为一个.obj文件,后者拥有PE[PortableExecutable,即windows可执行文件]文件格式,并且本身包含的就已经是二进制码,但是,不一定能够执行,因为并不保证其中一定有main函数。当编译器将一个工程里的所有.cpp文件以分离的方式编译完毕后,再由连接器(linker)进行连接成为一个.exe文件。对于