类模板

格式:

template<class NameType,class AgeType>
紧跟着类
与函数模板区别,可以有默认类型参数
自动类型推导,类模板不支持,必须显示指定类型
成员函数一开始不会创建出来,而是在运行时才会创建

例:

template<class NameType, class AgeType>

class Person

{

public:

    Person(NameType name, AgeType age)

    {

        this->Name = name;

        this->Age = age;

    }
    void showPerson()
    {
        cout << "名字:" <<this->Name << "年龄" << this->Age << endl;
    }

    NameType Name;

    AgeType Age;

};
void test()
{
    //自动类型推导,类模板不支持,必须显示指定类型
    Person<string, int> p("大魔王", 1000);
    p.showPerson();
};

类模板做函数参数

方式一:显示指定类型

方式二:参数模板化

方式三:整体类型化

例:

template<class NameType, class AgeType>

class Person

{

public:

    Person(NameType name, AgeType age)

    {

        this->Name = name;

        this->Age = age;

    }
    void showPerson()
    {
        cout << "名字:" << Name << "年龄" << Age << endl;
    }
    NameType Name;

    AgeType Age;

};
//指定传入类型
void doWork(Person<string, int>& p)
{
    p.showPerson();
};
void test()
{
    //自动类型推导,类模板不支持,必须显示指定类型
    Person<string, int> p("大魔王", 1000);
    doWork(p);
};

例2:

template<class NameType, class AgeType>

class Person

{

public:

    Person(NameType name, AgeType age)

    {

        this->Name = name;

        this->Age = age;

    }
    void showPerson()
    {
        cout << "名字:" << Name << "年龄" << Age << endl;
    }
    NameType Name;

    AgeType Age;

};
//参数模板化
template <class T1,class T2>
void doWork(Person<T1, T2>& p)
{
    p.showPerson();
};
void test()
{
    //自动类型推导,类模板不支持,必须显示指定类型
    Person<string, int> p("大魔王", 1000);
    doWork(p);
};

例3:

template<class NameType, class AgeType>

class Person

{

public:

    Person(NameType name, AgeType age)

    {

        this->Name = name;

        this->Age = age;

    }
    void showPerson()
    {
        cout << "名字:" << Name << "年龄" << Age << endl;
    }
    NameType Name;

    AgeType Age;

};
//整体类型化
template <class T>
void doWork(T& p)
{
    p.showPerson();
};
void test()
{
    //自动类型推导,类模板不支持,必须显示指定类型
    Person<string, int> p("大魔王", 1000);
    doWork(p);
};

查看数据的名称

cout<<typeid(数据名).name()<<endl;

类模板碰到继承

基类如果是模板类,必须让子类告诉编译器,基类中的T到底是什么类型,如果不告诉,那么无法分配内存

方式一:明确类型(利用参数列表)

class Child :public base<int>

例一:

template<class T>
class base
{
public:
    T m_A;
};
class Child :public base<int>
{

};

方式二:子类也是模板类

例二:

template<class T>
class base
{
public:
    T m_A;
};

template <class T1,class T2>
class Child :public base<T2>
{
public:
    Child(){
        cout << typeid(T1).name() << endl;
        cout << typeid(T2).name() << endl;
    }
    T1 m_B;
};
void test()
{
    Child<long, double>child;
    
};

类模板的类外实现成员函数

template <class T1,class T2>
类名<T1,T2>::类名(T1 name,T2 age)

例:

template<class T1,class T2>
class base
{
public:
    base(T1 name,T2 age);
    void showBase();
    T1 Name;
    T2 Age;
};

template <class T1,class T2>
base<T1,T2>::base(T1 name,T2 age)
{
    this->Name = name;
    this->Age = age;
}
template<class T1,class T2>
void base<T1, T2>::showBase()
{
    cout <<"姓名:" <<this->Name << endl;
    cout <<"年龄:"<< this->Age << endl;
}
void test()
{
    base<string,int> b("大魔王", 1000);
    b.showBase();
    
};

类模板的分文件编写

  • .h.cpp分别写声明和实现

  • 但是由于类模板的成员函数运行阶段才去创建,导致包含.h头文件,不会创建函数的实现,无法解析外部命令

  • 解决方案,

  • include .cpp文件(不建议)

  • 类模板不要做分文件编写,写到一个类中即可,类内进行声明和实现,最后把后缀名改为.hpp约定俗称

类模板碰到友元函数

友元函数类内实现

friend void printPerson(Person<T1,T2>&p)

类内实现例:

template<class T1,class T2>
class Person
{

    friend void printPerson(Person<T1, T2>& p)
    {
        cout << "姓名:" << p.Name << "年龄:" << p.Age << endl;
    }
public:
    Person(T1 name, T2 age)
    {
        this->Name = name;
        this->Age = age;
    }

private:
    T1 Name;
    T2 Age;
};


void test()
{
    Person<string,int> p("大魔王", 1000);
    printPerson(p);
    
};

友元函数类外实现

friend void printPerson<>(Person<T1,T2>&p);//没有<>普通函数声明,加上<>模板函数声明
让编译器看到这个函数并且看到这个Person类型

类外实现例:

template<class T1, class T2> class Person;
template<class T1, class T2>void printPerson(Person<T1, T2>& p);
template<class T1,class T2>
class Person
{
//友元声明
    friend void printPerson<>(Person<T1, T2>& p);
public:
    Person(T1 name, T2 age)
    {
        this->Name = name;
        this->Age = age;
    }

private:
    T1 Name;
    T2 Age;
};
template<class T1, class T2>
//实现
void printPerson(Person<T1, T2>& p)
{
    cout << "姓名:" << p.Name << "年龄:" << p.Age << endl;
};
void test()
{
    Person<string,int> p("大魔王", 1000);
    printPerson(p);
    
};
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 声明类模板类似于声明函数模板:在声明之前,您必须声明一个或多个模板参数,书中的使用了一个表示栈的示例,例如 也可以...
    铁甲万能狗阅读 370评论 0 0
  • C++中有一个重要特性,那就是模板类型。类似于Objective-C中的泛型。C++通过类模板来实现泛型支持。 1...
    岁与禾阅读 91,612评论 11 44
  • 注意:本文中代码均使用 Qt 开发编译环境,如有疑问和建议欢迎随时留言。 模板是 C++ 支持参数化程序设计的工具...
    赵者也阅读 5,680评论 1 5
  • 背景 C++ 是很强大,有各种特性来提高代码的可重用性,有助于减少开发的代码量和工作量。 C++ 提高代码的可重用...
    小林coding阅读 330评论 0 3
  • 今天的家长会,语文老师评价星烨上课总是不开口,上课爱站起来往后看,中午作业留一点没做完…我说星烨可能拼音比较薄弱,...
    童珠兰阅读 167评论 0 0