模板类的声明和定义中分离.h与.cpp

来源:互联网 发布:李小龙 命理 知乎 编辑:程序博客网 时间:2024/05/16 13:12

如果你用模板类的时候跟其它类一样把声明放在.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_

//呃,最后一个方法貌似不太好用。。。
原创粉丝点击