数据结构:模板

数据结构:模板

模板概述:

(1)模板是对具有相同特性的函数或类的再抽象,模板是一种参数化的多态性工具。

(2)所谓参数化多态性,是指将程序所处理的对象的类型参数化,使一段程序代码可以用于处理多种不同类型的对象。

(3)采用模板编程,可以为各种逻辑功能相同而数据类型不同的程序提供一种代码共享的机制。

 

模板分类:

函数模板、类模板

 

模板的实例化:

模板通过参数实例化可以构建具体的函数或类,称为模板函数和模板类。

 

①函数模板的定义:

 

template <模板形参表>

返回值类型  函数名(参数表){

        函数体

 }

例:(绝对值)

#include<iostream.h>

template<typename T>       //模板定义,T为模板参数

T abs(T a) {                  //定义函数模板

return a<0?-a:a;

}

 

template是模板定义的关键字。 <模板形参表>中包含一个或多个用逗号分开的模板形式参数,每一项均由关键字class或typename引导一个由用户命名的标识符,此标识符为模板参数(用来进行类型传递)

模板参数表示一种数据类型,可以是基本数据类型或类类型。该数据类型在发生实际函数调用时将被实例化,即用调用处的实际数据类型替代它。

 

②类模板的定义:

 

template <模板形参表>

class  类模板名

{

     成员的声明;

}

 

类模板中的成员函数的定义,若放在类模板的定义之中,则与类的成员函数的定义方法相同;若在类模板之外定义,则成员函数的定义格式如下:

template<模板形参表>

返回值类型  类模板名<形参名表>::成员函数名(参数表)

{

    成员函数体

}

 

类模板实例化:类模板名  <实际类型>

定义模板类的对象的格式:类模板名 <实际类型>  对象名(实参表);

 

之后顺序表和链表的定义都用到模板。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值