函数模板

函数模板

函数模板是通用函数的描述,通过泛型来定义函数。

模板格式

template<typename type>
void fun(type &a, type &b)
{
    type tmp;
    tmp = a;
    a = b;
    b = tmp;
}

注意:模板的定义与声明必须放在同一个h文件中,不能将声明放在h文件,定义放在c文件中。在模板函数中,并非所有的模板参数都必须是模板参数类型,也可以有非类型模板形参。

template<typename T1,typename T2, int N>  //这里的N便是非类型模板形参
void Swap(T1 *a,  T2 *b, int N);

模板的显示具体化,显示实例化

显示具体化

C++中的函数模板很可能无法处理某种类型,对于这种个别的特例,便可以使用显示具体化提供一个具体化函数定义。
比如:

struct job
{
    char name[40];
    double salary;
    int floor;
};
template<typename T>
void swap(T &a, T &b);

使用swap函数便可以交换结构体内容,但是当我想只交换结构体的salary内容时呢,使用通用函数模板便不能够达到要求,此时,使用显示具体化为这种特例提供一个具体化函数定义。

template<> void swap(job &a, jon &b) //显示具体化
{
    double t1; 
    t1 = a.salary;
    a.salary = b.salary;
    b.salary = t1
}

显示具体化的原型和定义都应该以template<>打头,并通过名称来指出类型。

显示实例化

函数模板并不是函数的定义,它只是一个用于生成函数定义的方案。当程序调用swap(i,j)的时候导致编译器生成了swap()的一个实例,这种实例称为隐式实例化。

int i; j;
swap(i,j) //实例化(隐式实例化)

C++还提供了显示实例化,显示实例化可以让编译器直接创建特定的实例。其语法类型为

template void Swap<int, int>;

显示实例化在template后没有<>,而显示具体化有。显示实例化没有函数体,因为在函数模板中已经定义了。在程序中也可以使用函数体创建显示实例化。

cout<<Swap<int>(x,m)<<endl;

我的理解:
显示具体化:不使用函数模板生成定义,而是使用专门的独立函数来定义生成函数。
显示实例化: 使用函数模板生成定义,编译器在调用函数模板的时候具有高的优先级。

编译器选择什么版本的函数模板

编译器选择规则是:
- 完全匹配
- 提升转换
- 标准转换
- 用户自定义的转换
具体内容待后面再补充

c++ primer
c++primer plus

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值