如果你用模板类的时候跟其它类一样把声明放在.h中那个,把定义放在.cpp中,是不是也出现了令人恼怒的 无法解析的外部符号 错误,在解决问题之前,请先看一下这篇关于编译原理的介绍,毕竟做学问要知其然更要知其所以然嘛~
http://www.doc88.com/p-841613271216.html
好啦,下面就是解决方法了:
-------------------------------------------------------------------------转自 路口---------------------------------------------------------------------------------------------
在类模板的声明和定义中把.h与.cpp分离
更新日期:2009-07-25 点击:1.声明部分 // Tpl.h
#pragma once
template<class T>
class CTpl
{
public:
CTpl();
virtual ~CTpl();
void Test(T t);
};
2.实现部分 // Tpl.cpp
#include "Tpl.h"
template<class T>
CTpl<T>::CTpl()
{
}
template<class T>
CTpl<T>::~CTpl()
{
}
template<class T>
void CTpl<T>::Test(T t)
{
} 3.习惯错误用法
// main.cpp
#include "Tpl.h"
int main()
{
CTpl<char> ts;
ts.Test(3);
return 0;
}
build时出现link错误
main.obj : error LNK2001: unresolved external symbol "public: virtual __thiscall CTpl::~CTpl(void)" (??1?$CTpl@D@@UAE@XZ)
main.obj : error LNK2001: unresolved external symbol "public: void __thiscall CTpl::Test(char)" (?Test@?$CTpl@D@@QAEXD@Z)
main.obj : error LNK2001: unresolved external symbol "public: __thiscall CTpl::CTpl(void)" (??0?$CTpl@D@@QAE@XZ)
这组错误信息和project中不加入Tpl.cpp的错误信息一样,即没有CTpl的实现代码
我们把Tpl.cpp包涵到main.cpp中,问题解决
4.正确用法
// main.cpp
#include "tpl.cpp"
int main()
{
CTpl<char> ts;
ts.Test(3);
return 0;
}
5.总结
1.在使用以.h,.cpp分离实现模板类时,不能像使用普通类一样只简单的包涵.h头文件,应该在使用模板类的cpp文件中引入模板类相应的cpp文件
2.将模板类的声明与实现都放在.h中(在多个cpp中使用不同模板参数时可能会引起重复定义的编译错误)
也可以采用如下的方式:
呵呵。要在类声明后放#include "yourfilename.h",而不是在.h文件头上.
在头文件里include 模板定义的cpp文件实现声明与定义的文件分离
/* xxx.h file*/
#ifndef _XXX_H_
#define _XXX_H_
template <class T>
class XXX
{};
#include "xxx.cpp"
#endif // _XXX_H_