STL入门.pptVIP

  1. 1、本文档共81页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
STL入门ppt课件

STL入门 导入 STL的概念与组成 Iterator(迭代器) Container(容器) Algorithm(算法) Adaptors(配接器) 导入  抽象的重要性 计算机科学的重要进步,许多是由于发掘了新的抽象性质而促成的 面向过程->基于对象->面向对象   ->泛型   导入  面向过程(Procedure-Oriented)的抽象 抽象出Procedure(Function)的概念,把程序分成若干个子过程。将事物的方法隐藏于各个函数内--C语言。 适用于处理小型的程序。对大型程序, 子程序之间关系复杂,不易处理变化的需求--引发软件危机的原因--需要新的抽象。 导入  面向过程示例 导入  基于对象(Object-Based)的抽象 引入抽象数据类型(ADT,Abstract Data Type)。C++的类,将事物的属性与方法紧密地结合在一起--VB、带类的C。 与面向过程相比,可以更好地处理变化,一定程度上化解了软件危机。但各个类之间的关系不容易处理,而且程序代码数量比面向过程时更大--需要新的抽象。 导入  示例 导入  面向对象(Object-Oriented)的抽象 抽象出封装、继承、多态( polymorphic )的概念。 与基于对象相比,有更多的间接性。运用多态,我们可以调用某种方法,而不用指定此方法所属的类型。因而达到更进一步的抽象性。 它为我们带来了什么?--MFC(用面向对象技术封装Windows API,抽象出一个类体系) 导入  示例 MFC类体系图 导入 泛型(Generic)的概念 Generic是一种抽象 就如 OO是一种抽象。 还没有语法与之相对应--正在开发中。 (Function、Class、D : public B) 它为我们带来了什么?--STL。 STL的概念  何为STL? STL(Standard Template Library)是C++标准庫的一部分(80%),是用C++ Template机制来表达泛型的庫。 STL(Standard Template Library)是用泛型技术来设计完成的实例 就如 MFC(Microsoft Foundational Classes)是用面向对象技术来设计完成的实例 STL的概念  STL抽象的是什么? 有些算法并不依赖于数据结构的特定实现,而只是依赖于该结构的几个基本的语义属性. STL抽象出这些基本属性(Concept),成功的将算法与数据结构分离,在没有效率损失的前提下,得到了及大的弹性。 STL的概念  示例 STL的组成 六大组件 容器(Container) 算法(Algorithm) 迭代器(Iterator) 仿函数(Function object) 适配器(Adaptor) 空间配制器(allocator) STL的组成 STL在哪里? 后缀名? Namespace std 相关资料 STL之父访谈录 --详细介绍了STL的历史,点明了STL的设计宗旨以及它与OO的关系。 复习C++ Template机制。 习题: STL example1、STL example2 新的语言特性 Namespace(名字空间) Template的新特性 新的类型转换运算符 命名空间(Namespace) 现在的软件多以程序庫、模块、组件拼凑而成,名称冲突问题越来越严重。Namespace就是用来解决此问题的。 Namespace将不同的标识符号集合在一个具体的名称范围内。 命名空间(Namespace) Namespace的名字和标识符号间以 : :分隔 (类似于Class 与 members之间) 命名空间(Namespace) 与类不同的是,Namespace是开放的。 命名空间(Namespace) using declaration,我们可以避免一再写出冗长的namespace名称 using directive 命名空间(Namespace) using directive会再度引发名称冲突 Template的新特性 类模板显示特化(class template explicit specialization ) Template的新特性 类模板偏特化(class template partial specialization) Template的新特性 默认模板参数 Template的新特性 成员模板(member template) Template的新特性 关键字 typename 做为类型前的标识符号。 Template的新特性 关键字 typename C++的一般规则是,除了以typename修饰

文档评论(0)

118zhuanqian + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档