C++函数模板的显式具体化

本文探讨了C++函数模板的局限性,特别是当处理数组和结构体时遇到的问题。为解决这一问题,文章介绍了显式具体化概念,这是一种创建针对特定类型的具体函数模板实现的方法。显式具体化在编译器找到匹配的具体化定义时优先于常规模板,且非模板函数优先级最高。文中还给出了显式具体化的定义形式和实例。
摘要由CSDN通过智能技术生成

C++函数模板的显式具体化

1.函数模板的局限性

在C++中,我们可以使用函数模板来增加代码的复用性,但是并不是所有的类型都可以调用函数函数模板来处理,如数组和结构体数据类型。这就是函数模板的局限性。

struct job{
   
	char name[10];
	double salary;
	int floor;
}
//交换两个这种结构的内容,原来的模板使用以下代码进行交换:
	temp=a;
	a=b;
	b=temp;

由于C++允许将一个结构赋给另一个结构,因此即使T是job结构,上述代码也适用。假设我们只想要交换salary和floor成员,而不交换name成员,则需要使用不同的代码,但Swap()的参数将保持不变,因此无法使用模板重载来提供其他的代码。
我们可以提供一个具体化函数定义——显式具体化,其中包括所需代码,当编译器找到与函数调用匹配的具体化定义时,将使用该定义,不再寻找模板。

2.显式具体化

C++标准的定义形式:

1.对于给定的函数名,可以有非模板函数,模板函数和显式具体化模板函数以及他们的重载版本。
2.显式具体化的原型和定义应以template<>打头,并通过名称来指出类型。
2.具体化优先于常规模板,而非模板函数优先于具体化和常规模板。

下面是用于交换job结构的非模板函数、模板函数和具体化的原型:

//非模板函数
void swap(job &a,job &b);
//模板函数
template<typename T>
void swap(T &,T &)
<
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值