STL:函数模板

1.函数模板
使用模板 类型参数化 编写代码可以忽略类型

2.函数模板和类模板
函数模板针对仅参数类型不同的函数
类模板针对仅数据成员和成员函数类型不同的类

3.函数模板通式
template 只对其后的第一个函数有效

template <class 形参名,class 形参名,......>
返回类型 函数名(参数列表)
{
函数体
}

4.调用函数模板的两种方式

  • 自动类型推导
  • 显示的指定类型
template<class T>   // template<typename T>
void mySwap(T &a, T &b)
{
	T temp = a;
	a = b;
	b = temp;
}

//使用函数模板
void test01(){
	//1. 自动类型推导  编译器根据你传进去的值进行类型自动推导
	int a = 10;
	int b = 20;
	cout << "a:" << a << "  b:" << b << endl;
	mySwap(a, b);
	cout << "a:" << a << "  b:" << b << endl;

	double da = 1.13;
	double db = 1.14;
	cout << "da:" << da << "  db:" << db << endl;
	mySwap(da, db);
	cout << "da:" << da << "  db:" << db << endl;
 

	//2. 显示的指定类型
	a = 10;
	b = 20;
	cout << "a:" << a << "  b:" << b << endl;
	mySwap<int>(a, b);
	mySwap<>(a, b);   
	cout << "a:" << a << "  b:" << b << endl;

5.函数模板和普通函数的区别
普通函数可以进行自动类型转换 但是函数模板必须严格类型匹配
比如一个参数为int的普通函数 你可以传short和char作为参数 但是函数模板不行

6.函数模板和普通函数在一起的调用规则

  • 函数模板可以像普通函数那样被重载
//1.模板重载
template<class T>
void myPrint(T a)
{
	cout << a << endl;
}

template<class T1, class T2>
void myPrint(T1 a, T2 b)
{
	cout << a << "  " << b << endl;
}
  • C++编译器优先考虑普通函数
  • 如果函数模板可以产生一个更好的匹配,那么选择模板
  • 可以通过空模板实参列表的语法限定编译器只能通过模板匹配,例如 mySwap<>(a, b);
    7.函数模板编译过程
    编译器会对函数模板进行两次编译
  • 在声明模板的地方对模板代码本身进行编译
  • 在调用的地方对参数进行替换后的模板函数的代码进行编译
    通过函数模板产生模板函数,编译器会根据调用的参数类型,产生模板函数 。编译器并不是把函数模板处理成能够处理任何类型的函数。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值