C++模板

模板 是 泛型编程的基础

泛型编程:编写与类型无关的通用代码,是代码复用的一种手段

函数模板

函数模板在使用时才会被参数、实例化,根据实参类型生成函数的特定版本

cpp 复制代码
template<class T>
// template<typename>
size_t multi(const T& a, const T& b)
{
	return a * b;
}

class & typename

在模板声明形参 T 时,class T 或者 typename T 是完全等价的,但如果有下面情况,必须用 typename

cpp 复制代码
template<typename T>
// template<class>
void print_list(const list<T>& lt)
{
	typename list<T>::const_iterator it = lt.begin();
	......
}

这是在 模板函数 print_list 中,包括了 模板类 list<T> :

const_iterator 是一个内嵌类型,即 嵌套在模板类 list<T> 中的内置类型;

编译器在实例化 list<T> 之前,不清楚 const_iterator 到底是一个内嵌类型,还是一个静态成员变量;

因为静态成员变量也有同样的突破类域的访问方式:类名::成员名 ,其实不仅静态成员变量,静态成员函数也是这样的访问方式;

所以回归问题,我们必须 使用typename 告诉编译器 const_iterator 是一个内嵌类型,等 list<T> 实例化之后,去实例化的类里面找。

模板 & 同名函数

cpp 复制代码
template<class T>
size_t multi(const T& a, const T& b)
{
	return a * b;
}
int multi(const int& left, const int& right)
{
	return left * right;
}

函数模板与同名函数同时存在,调用时,编译器能先调同名函数就会先调同名函数;

如果想指定调模板,那么需要显式实例化:

cpp 复制代码
	int a = 1, b = 2;
	multi<char>(a, b);    // 函数模板的显式实例化

显式实例化

除了上面提到 如果想指定调用函数模板需要显式实例化参数类型之外,还有一种情况:

cpp 复制代码
template<class T>
T& func(int n)
{
	return new T[n];
}

func<char>(10);    // 必须显式实例化

调用这个模板函数时,编译器无法通过你传入的参数来推理出 模板参数 T 是什么类型,所以必须显式实例化。

类模板

类模板必须显式实例化:

cpp 复制代码
template<class T>
class A
{
public:
	A()
		:_a(0)
		,_b(nullptr)
	{}
private:
	T _a;
	T* _b;
};

A<int> a;    // 类模板的显式实例化

这个类的类名是 A , 类型是 A<T>

类模板的使用 参考函数模板。

相关推荐
m0_5522008244 分钟前
《UE5_C++多人TPS完整教程》学习笔记43 ——《P44 奔跑混合空间(Running Blending Space)》
c++·游戏·ue5
DokiDoki之父1 小时前
多线程—飞机大战排行榜功能(2.0版本)
android·java·开发语言
八个程序员1 小时前
c++计算器(简陋版)
c++·游戏
whatever who cares1 小时前
Java 中表示数据集的常用集合类
java·开发语言
xy_recording1 小时前
Day08 Go语言学习
开发语言·学习·golang
EndingCoder1 小时前
测试 Next.js 应用:工具与策略
开发语言·前端·javascript·log4j·测试·全栈·next.js
吧唧霸1 小时前
golang读写锁和互斥锁的区别
开发语言·算法·golang
mjhcsp1 小时前
C++小游戏NO.1游戏机
c++·游戏
还梦呦2 小时前
2025年09月计算机二级Java选择题每日一练——第一期
java·开发语言
♞沉寂2 小时前
信号以及共享内存
linux·c语言·开发语言