c++不接受模板分离式编译的原因及其解决方法

首先呢,先了解一下什么是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文件。对于

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值