当类模板碰到继承
基类如果是模板类,必须让子类告诉编译器 基类中的T到底是什么类型
如果不告诉,那么无法分配内存,编译不过
利用参数列表class Child :public Base<int>
main.cpp
#define _CRT_SECURE_NO_WARNINGS
#include<iostream>
using namespace std;
template <class T>
class Base
{
public:
T m_A; //double类型
};
//child继承与 base必须告诉base中的T的类型,否则T无法分配内存
class Child :public Base<int>
{
};
//child2 也是模板类
template<class T1, class T2>
class Child2 :public Base<T2>
{
public:
Child2()
{
cout << "typeid(T1).name()==== " << typeid(T1).name() << endl;
cout << "typeid(T2).name()==== " << typeid(T2).name() << endl;
}
public:
T1 m_B; //int类型
};
void test01()
{
Child2<int, double>child;//由用户指定类型
/*输出
ypeid(T1).name()==== int
typeid(T2).name()==== double
*/
}
int main(){
test01();
system("pause");
return EXIT_SUCCESS;
}
类外实现成员函数
#define _CRT_SECURE_NO_WARNINGS
#include<iostream>
using namespace std;
#include <string>
template<class T1, class T2>
class Person
{
public:
Person(T1 name, T2 age);
//类内部实现
//{
// this->m_Name = name;
// this->m_Age = age;
//}
void showPerson();
//类内部实现
//{
// cout << "姓名:" << this->m_Name << " 年龄: " << this->m_Age << endl;
//}
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>::showPerson()
{
cout << "姓名:" << this->m_Name << " 年龄: " << this->m_Age << endl;
}
void test01()
{
Person <string, int> p1("aaaaa", 100);
p1.showPerson();//输出:姓名:aaaaa 年龄: 100
}
int main(){
test01();
system("pause");
return EXIT_SUCCESS;
}
类模板的分文件编写问题以及解决
.h .cpp分别写声明和实现
但是由于 类模板的成员函数运行阶段才去创建,导致包含.h头文件,不会创建函数的实现,无法解析外部命令
解决方案 保护 .cpp文件 (不推荐)
不要进行分文件编写,写到同一个文件中,进行声明和实现,后缀名改为.hpp
约定俗成的
main.cpp
#define _CRT_SECURE_NO_WARNINGS
#include<iostream>
#include <string>
using namespace std;
#include "Person.hpp"
//建议 模板不要做分文件编写,写到一个类中即可,类内进行声明和实现,最后把后缀名改为.hpp 约定俗成
int main(){
Person<string, int>p("猪八戒", 10);
p.showPerson();
system("pause");
return EXIT_SUCCESS;
}
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 showPerson();
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>::showPerson()
{
cout << "姓名:" << this->m_Name << " 年龄: " << this->m_Age << endl;
}