资源描述:
《c++模板&stl库教程》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库。
1、C++模板与STL库介绍第8章提纲1.概论2.模板机制的介绍3.STL中的基本概念4.容器概述5.迭代器6.算法简介概论C++语言的核心优势之一就是便于软件的重用C++中有两个方面体现重用:1.面向对象的思想:继承和多态,标准类库2.泛型程序设计(genericprogramming)的思想:模板机制,以及标准模板库STL这次课的重点泛型程序设计泛型程序设计,简单地说就是使用模板的程序设计法。将一些常用的数据结构(比如链表,数组,二叉树)和算法(比如排序,查找)写成模板,以后则不论数据结构里放的是什么对象,算法针对什么样的对象,则都不必重新实现数据结构,重新编写算法。标准模板库(S
2、tandardTemplateLibrary)就是一些常用数据结构和算法的模板的集合。主要由AlexStepanov开发,于1998年被添加进C++标准有了STL,不必再从头写大多的标准数据结构和算法,并且可获得非常高的性能。模板引子1.假如设计一个求两参数最大值的函数,在实践中我们可能需要定义四个函数:intmax(inta,intb){return(a>b)?a,b;}longmax(longa,longb){return(a>b)?a,b;}doublemax(doublea,doubleb){return(a>b)?a,b;}charmax(chara,charb){ret
3、urn(a>b)?a,b;}2.这些函数几乎相同,唯一的区别就是形参类型不同3.需要事先知道有哪些类型会使用这些函数,对于未知类型这些函数不起作用intabs(inta){returna<0?-a:a;}doubleabs(doublea){returna<0?-a:a;}数据为int或double时的求绝对值问题classSquare1{public:Square1(inty):x(y){}intfun(){returnx*x;}private:intx;};用类实现求一个数的平方classSquare2{public:Square(doubley):x(y){}doublefu
4、n(){returnx*x;}private:doublex;};样例:求最大值模板函数实现1.求两个数最大值,使用模板templateTmax(Ta,Tb){return(a>b)?a,b;}2.template<模板形参表>//模板声明格式<返回值类型><函数名>(模板函数形参表){//函数定义体}8模板的概念所谓模板是一种使用无类型参数来产生一系列函数或类的机制。若一个程序的功能是对某种特定的数据类型进行处理,则可以将所处理的数据类型说明为参数,以便在其他数据类型的情况下使用,这就是模板的由来。模板是以一种完全通用的方法来设计函数或类而不必预先说明将被使用的每
5、个对象的类型。通过模板可以产生类或函数的集合,使它们操作不同的数据类型,从而避免需要为每一种数据类型产生一个单独的类或函数。注意:●模板并非通常意义上可直接使用的函数或类,它仅仅是对一族函数或类的描述,是参数化的函数和类。●模板是一种使用无类型参数来产生一族函数或类的机制。模板分类函数模板(functiontemplate)是独立于类型的函数可产生函数的特定版本类模板(classtemplate)跟类相关的模板,如vector可产生类对特定类型的版本,如vector11模板工作方式函数模板只是说明,不能直接执行,需要实例化为模板函数后才能执行在说明了一个函数模板后,当编译
6、系统发现有一个对应的函数调用时,将根据实参中的类型来确认是否匹配函数模板中对应的形参,然后生成一个重载函数。该重载函数的定义体与函数模板的函数定义体相同,它称之为模板函数12#includetemplateTmin(Ta[],T1n){inti;Tminv=a[0];for(i=1;ia[i])minv=a[i];}returnminv;}编写一个对具有n个元素的数组a[]求最小值的程序,要求将求最小值的函数设计成函数模板。voidmain(){inaa[]={1,3,0,2,7,6,4,5,2};
7、doubleb[]={1.2,-3.4,6.8,9,8};cout<<”a数组的最小值为:”<