- 1、本文档共30页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
[PPT模板]模板与STL
* * * * * * * * * * * * * * * * * * * * * * * * * * * 专业教程 理论讲解部分 网络游戏开发-C++程序设计 第9章 模板与STL 第9章 模板与STL 函数模板 类模板 模板的概念 类模板的定义和使用 类模板中的静态成员和友元 类模板中的特例版本 理解模板技术 掌握函数模板的使用 掌握类模板的使用 第9章 模板与STL 9.1 模板 模板(templates) 针对“一个或多个尚未明确的数据类型(包括类类型)”所设计的函数或类。 在不确定要操作数据的类型的情况下就实现操作方法。 模板是在函数和类的基础上提供了更高一层的抽象。 第9章 模板与STL 9.1 模板 9.1.1 函数模板 1.函数模板的概念 利用函数模板(带类型参数的函数),一次定义出具有共性的一组函数。 除类型参数外 函数名相同,参数个数相同 返回类型可以不同 处理多种不同类型数据的函数 第9章 模板与STL 9.1 模板 9.1.1 函数模板 1.函数模板的概念 int max (int a, int b) { //函数max,求两个int 型数据的最大值 if(ab) return a; else return b; } double max (double a, double b) { //重载函数max,求两个double 型数据的最大值 if(ab) return a; else return b; } … template class T T max (T a, T b) { if(ab) return a; else return b; } 重载函数 函数模板 第9章 模板与STL 9.1 模板 9.1.1 函数模板 2.函数模板的说明 template 模板参数表 函数定义; template:关键字。指明为函数模板或类模板。 模板参数表:用尖括号括起来,一个或多个模板参数,用“,”分开。 模板参数:其格式为class类名,其中的类名是一个标识符,该类名对应的实参类型可以是任何类型。 返回类型 函数名(参数表){函数体}; 第9章 模板与STL 9.1 模板 9.1.1 函数模板 2.函数模板的说明 函数模板在被调用时与同名的函数调用没有什么区别 函数调用过程: 1)首先搜索程序说明中是否有参数表恰与max(c1,c2)之参数表完全相同的同名函数,如果有,就调用此函数代码付诸执行。否则执行下一步; 2)检查是否有函数模板,经适当实例化成为参数匹配的同名函数。如果有,调用此实例化的模板函数代码付诸执行。否则执行下一步; 第9章 模板与STL 9.1 模板 9.1.1 函数模板 2.函数模板的说明 3)检查是否有同名函数,可经参数的自动转换后实现参数匹配。如果有,调用该函数代码付诸执行; 4)如果三种情况都未找到匹配函数,则按出错处理; 5)值得注意的是,模板函数调用时,与一般函数不同之处在于,它不允许类型的转换。 模板函数也可以重载。同样,重载的条件是二同名模板函数必须有不同的参数表。 第9章 模板与STL 9.1 模板 9.1.1 函数模板 3.函数模板应用举例 #include iostream using namespace std; //第一个函数模板sum,使用了一个类型参数Type,具有两个形参 //本函数模板sum 的功能为:求出array 数组的前size 个元素之和并返回 template class Type Type sum (Type * array, int size ) { Type total=0; for (int i=0;isize;i++) //累加前size 个数到total total+=*(array+i); return total; } 第9章 模板与STL 9.1 模板 9.1.1 函数模板 3.函数模板应用举例 //功能:求出a1 数组与a2 数组的前size 个元素之和并返回 template class Type Type sum (Type * a1, Type * a2, int size ) { Type total=0; for (int i=0;isize;i++) //累加a1 数组与a2 数组的前size 个数到total total+=a1[i]+a2[i]; return total; } void main() { int a1[10]={1, 2, 3, 4, 5, 6, 7, 8, 9, 10}; int a2[8]={2, 4, 6, 8, 10, 12, 14, 16};
您可能关注的文档
- [PPT模板]安大略省的竞争优势.ppt
- [PPT模板]小脑血管性疾病2012.ppt
- [PPT模板]字体标志设计.ppt
- [PPT模板]山潍拖医院工作制度.doc
- [PPT模板]工程经济学ppt第三章 资金的时间价值与等值计算.ppt
- [PPT模板]常用事务类文书的制作.ppt
- [ppt模板]幸福培训用.ppt
- [PPT模板]局部放电-gaoji.ppt
- [PPT模板]应用文写作第八章.ppt
- [PPT模板]应用文写作.ppt
- 社会服务行业:关注文旅结合IP的新消费延伸.pdf
- 人形机器人产业2025年中期投资策略:智启新程,人形进阶.pdf
- 3C消费电子行业三大市场增长报告:中国×欧美×东南亚,消费电子的未来战场,中国智造 “卷” 向全球.pdf
- 一堂全面开放的阅读课特级教师于永正《全神贯注》教学赏析.doc
- 村委会2025个人年度工作计划.docx
- 一季度公司职工政治学习提纲.doc
- 一元二次方程概念、解法、根的判别式(讲义及答案).docx
- 社会服务行业:关注文旅结合IP的新消费延伸.docx
- 基础化工行业2025年中期投资策略:拨云见日终有时,关注细分领域结构性机会.pdf
- 2025年大模型云市场探析:如何重构企业智能化路径,开启大模型产业新浪潮?.docx
文档评论(0)