1.问题引入: 当使用类模板的成员函数的具体实现与声明分别写在不同的文件时,出现错误,使用vs作为IDE。
错误代码:
main.cpp
#include"person.h"
void test01() {
Person<string, int> p("赵云", 38);
p.showPerson();
}
int main() {
test01();
return 0;
}
person.h
#pragma once
#include<iostream>
#include<string>
using namespace std;
template<class T1, class T2>
class Person {
private:
T1 m_Name;
T2 m_Age;
public:
Person(T1 name, T2 age);
void showPerson();
};
person.cpp
#include"person.h"
template<class T1, class T2>
Person<T1, T2>::Person(T1 name, T2 age) {
m_Name = name;
m_Age = age;
}
template<class T1, class T2>
void Person<T1, T2>::showPerson() {
cout << "姓名:" << this->m_Name
<< ", 年龄:" << this->m_Age << endl;
}
运行上面的代码,就会出现链接错误。
原因分析:因为类模板的成员函数,是在实例化对象之后,调用时才会创建,所以在main函数所在文件包含类声明的person.h头文件,编译器无法查看到person.cpp里的函数实现代码,导致出错。
推荐解决方法:
把声明和具体实现都写在头文件里,并且把头文件后缀写为hpp。在main函数所在文件里包含hpp文件。
即
person.hpp
#pragma once
#include<iostream>
#include<string>
using namespace std;
template<class T1, class T2>
class Person {
private:
T1 m_Name;
T2 m_Age;
public:
Person(T1 name, T2 age); //声明
void showPerson();
};
//类外实现
template<class T1, class T2>
Person<T1, T2>::Person(T1 name, T2 age) {
m_Name = name;
m_Age = age;
}
template<class T1, class T2>
void Person<T1, T2>::showPerson() {
cout << "姓名:" << this->m_Name
<< ", 年龄:" << this->m_Age << endl;
}