类模板分文件编写有两种方法:
1.直接包含.cpp源文件
2.将声明和实现写到同一文件中,并更改后缀名为.hpp(并不是一定要设为.hpp,但大部分程序员都这样设,这是约定俗成的)
为什么不能像普通的类那样分文件编写呢:
因为类模板中的成员函数创建时机是在调用阶段,这导致分文件编写时链接不到(按照普通类的分文件编写在创建成员函数时系统只能看到 ‘.h’ 头文件,而看不到 ‘.cpp’ 源文件,所以无法成功创建成员函数)
因为我们大部分人的习惯都是包含头文件,所以第一种直接包含.cpp源文件的方法是不常用的,我们常用的是第二种方法,所以当你看到程序中包含了.hpp头文件,一般都是类模板的定义和实现文件。
1.直接包含.cpp源文件代码:
text.cpp执行源文件
#include<iostream>
using namespace std;
#include"person.cpp"
int main()
{
person<string, int>p("张三", 18);
p.show_person();
return 0;
}
person.h类模板头文件
#pragma once
#include<iostream>
using namespace std;
template<class T1,class T2>
class person
{
public:
person(T1 name, T2 age);
void show_person();
private:
T1 m_name;
T2 m_age;
};
person.cpp类模板源文件
#include"person.h"
template<class T1, class T2>
person<T1, T2>::person(T1 name, T2 age)
{
this->m_name = name;
this->m_age = age;
}
template<class T1, class T2>
void person<T1, T2>::show_person()
{
cout << m_name << endl;
cout << m_age << endl;
}
2.将声明和实现写到同一文件中,并更改后缀名为.hpp代码:
text.cpp执行源文件
#include<iostream>
using namespace std;
#include<string>
#include"person.hpp"
int main()
{
person<string, int>p("张三", 18);
p.show_person();
return 0;
}
person.hpp类模板定义与实现头文件
#pragma once
#include<iostream>
#include<string>
using namespace std;
template<class T1, class T2>
class person
{
public:
person(T1 name, T2 age);
void show_person();
private:
T1 m_name;
T2 m_age;
};
template<class T1, class T2>
person<T1, T2>::person(T1 name, T2 age)
{
this->m_name = name;
this->m_age = age;
}
template<class T1, class T2>
void person<T1, T2>::show_person()
{
cout << m_name << endl;
cout << m_age << endl;
}