模板类成员函数定义问题
问题描述:通常C++程序大都以动态库的形式提供给他人调用,.h中包含接口的声明及导出,在.cpp文件中实现。提供给他人的只有.h文件和库文件。这样的话保证了源码不会泄露。然而,对于模板类如果做以下声明及实现:
#pragma once
// filename TempClass.h
template<class T>
class TempClass
{
public:
TempClass(T t);
~TempClass();
};
//filename TempClass.cpp
#include "stdafx.h"
#include "TempClass.h"
#include <iostream>
template<class T>
TempClass<T>::TempClass(T t)
{
std::cout << t << std::endl;
}
template<class T>
TempClass<T>::~TempClass()
{
}
// TempTest.cpp : 定义控制台应用程序的入口点。
//
#include "stdafx.h"
#include "TempClass.h"
int main()
{
TempClass<double> asdf(3.3);
return 0;
}
编译时会提示错误:
TempTest.obj : error LNK2019: 无法解析的外部符号 "public: __thiscall TempClass<double>::TempClass<double>(double)" (??0?$TempClass@N@@QAE@N@Z),该符号在函数 _main 中被引用
TempTest.obj : error LNK2019: 无法解析的外部符号 "public: __thiscall TempClass<double>::~TempClass<double>(void)" (??1?$TempClass@N@@QAE@XZ),该符号在函数 _main 中被引用
这里是因为在编译cpp过程中,编译器无法识别出TempTest到底是啥,所以无法识别。
解决办法如下:
一:添加asdf.cpp(名字自己取),将模板类的函数实现单独放入,并在.h中包含该文件。
二:在.cpp中添加如下代码:
template class TempClass<double>;
template class TempClass<int>;
这样也只能保证,在使用模板类时可以使用以上数据类型,那么就失去了模板的本意。