1. 类模板
类模板和函数模板的定义和使用类似,我们已经进行了介绍。有时,有两个或多个类,其功能是相同的,仅仅是数据类型不同。
- 类模板用于实现类所需数据的类型参数化
#include<iostream>
#include<string>
using namespace std;
//类模板和函数模板的定义和使用类似,我们已经进行了介绍。有时,有两个或多个类,其功能是相同的,仅仅是数据类型不同。
//类模板用于实现类所需数据的类型参数化
template<class T1,class T2 = int>//类模板可以指定一个默认参数类型
class person
{
public:
person(T1 name,T2 age)
{
this->n_name =name;
this->n_age =age;
}
void printer()
{
cout<<"person.n_name:"<<this->n_name<<" "<<"person.n_age:"<<this->n_age<<endl;
}
private:
T1 n_name;
T2 n_age;
};
void main(){
//类型//person p;//类模板不能进行自动推导
person<string,int>p1("jojo",20);
p1.printer();
}
1.1 类内成员函数的创建时机
#include<iostream>
#include<string>
using namespace std;
class person1
{
public:
void showperson1()
{
cout<<"person1"<<endl;
}
};
class person2
{
void showperson2()
{
cout<<"person2"<<endl;
}
};
template<class T>
class typeend
{
public:
T obj;
//成员函数不会一开始就创建出来,而是在运行的时候创建
void show1()
{
obj.showperson1();
}
void show2()
{
obj.showperson2();
}
};
void main()
{
typeend<person1>p1;//不会报错,生成类的时候并没有直接生成成员函数
p1.show1();
//p1.show2();
}
成员函数不会一开始就创建出来,而是在运行的时候创建
1.3 类模板做函数参数
//类模板
template<class NameType, class AgeType>
class Person{
public:
Person(NameType name, AgeType age){
this->mName