C++模板

本文详细介绍了C++中的类模板,包括其与函数模板的区别、成员函数创建时机、作为函数参数的传递方式、与继承的结合、类模板成员函数的外部实现以及分文件编写时的注意事项。还探讨了类模板与友元函数的使用,展示了全局函数类内和类外实现友元的示例。通过实例解析,帮助读者深入理解类模板的高级用法。
摘要由CSDN通过智能技术生成

2.类模板

语法

template<class  T>

#include <iostream>
using namespace std;

template<class Nametype,class Agetype>
class Person
{
public:
	Person(Nametype name, Agetype age)
	{
		this->name = name;
		this->age = age;
	}
	Nametype name;
	Agetype age;
};

int main()
{
	Person<string, int>p1("猴", 20);
	cout << p1.age << " " << p1.name << endl;
}

1)类模板和函数模板的区别

1.类模板没有自动类型推导的使用方式

2.类模板在模板参数列表中可以有默认参数 

#include <iostream>
using namespace std;

template<class Nametype,class Agetype=int>
class Person
{
public:
	Person(Nametype name, Agetype age)
	{
		this->name = name;
		this->age = age;
	}
	Nametype name;
	Agetype age;
};

int main()
{
	Person<string>p1("猴", 20);
	cout << p1.age << " " << p1.name << endl;
}

2)类模板中成员函数创建时机

普通类中的成员函数一开始就可以创建

类模板中成员函数调用时才创建

3)类模板对象作函数参数 

三种传入方式

1:指定传入的类型

2:参数模板化

3:整个类模板化

#include <iostream>
using namespace std;

template<class T1,class T2>
class Person
{
public:
    Person(T1 name, T2 age)
    {
        this->m_Age = age;
        this->m_Name = name;
    }

    void show()
    {
        cout << m_Age << " " << m_Name << endl;
    }
    T1 m_Name;
    T2 m_Age;
};

//1.指定传入的类型
void Print1(Person<string, int>&p)
{
    p.show();
}

//2.参数模板化
template <class T1,class T2>
void Print2(Person<T1,T2>&p)
{
    p.show();
    //显示指定类型
    cout << typeid(T1).name() << endl;
    cout << typeid(T2).name() << endl;
}

//3.类模板化
template <class T>
void Print3(T &p)
{
    p.show();
    //显示指定类型
    cout << typeid(T).name() << endl;
}

int main()
{
    Person<string, int>p("猴", 20);
    Print1(p);
    Print2(p);
    Print3(p);
}

4)类模板与继承 

template <class T>

class Father

{

        T   a;
};

class Son:public Father <int>  必须指定数据类型传入父类

 为了灵活选择数据类型,子类也为类模板

#include <iostream>
using namespace std;

template<class T>
class Father
{
	T  a;
};


template <class T1, class T2>
class Son :public Father<T2>
{
public:
	Son()
	{
		cout << typeid(T1).name() << endl;
		cout << typeid(T2).name() << endl;
	}
	T1 a;
};

int main()
{
	Son<string, char>son;
}

5)类模板成员函数类外实现

这个比较简单,和成员函数类外实现一样,只需要显式指定类型即可

#include <iostream>
using namespace std;

template <class T1,class T2>
class Person
{
public:
	Person(T1 name, T2 age);
	void show();

	T1 name;
	T2 age;
};

template <class T1,class T2>
Person<T1, T2>::Person(T1 name, T2 age)
{
	this->age = age;
	this->name = name;
}

template <class T1, class T2>
void Person<T1, T2>::show()
{
	cout <<this-> name << endl;
	cout <<this-> age << endl;
}

int main()
{
	Person<string, int>p("猴", 20);
	p.show();
}

6)类模板分文件编写

类模板成员函数创建时机在调用阶段,导致分文件编写时链接不到

解决方法:

1.直接包含.cpp源文件

2.将声明和实现写到同一个文件中,并更改后缀名为.hpp 

7)类模板与友元

1.全局函数类内实现  ------类内声明友元

2.全局函数类外实现  ------提前让编译器知道全局函数存在

#include <iostream>
using namespace std;

//全局函数类外实现
template <class T1 ,class T2>
class Person;

template <class T1, class T2>
void show2(Person<T1, T2> p)
{
	cout << p.name << p.age;
}


template <class T1,class T2>
class Person
{
	//全局函数类内实现
	friend  void show1(Person<T1, T2> p)
	{
		 cout << p.name << p.age;
	}
	全局函数类外实现 函数模板
	friend  void show2<>(Person<T1, T2> p);

public:
	Person(T1 name,T2 age)
	{
		this->age = age;
		this->name = name;
	}
private:
	T1 name;
	T2 age;
};


void test01()
{
	Person<string, int>p("猴子", 20);
	show1(p);
}

void test02()
{
	Person<string, int>p("猴子", 20);
	show2(p);
}
int main()
{
	test01();
	test02();
}

 

 

 

 

 

 

 

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值