C++程序的设计教程11.pptVIP

  1. 1、本文档共17页,可阅读全部内容。
  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文档。上传文档
查看更多
C++程序设计教程(第二版) 第十一章 基于对象编程 Chapter 11 Object-Based Programming 第十一章内容 1. 抽象编程 ( Abstract Programming ) 抽象分行为抽象和数据抽象两种. 行为抽象:通俗地说便是将一个行为序列归并(抽象)为一个行为的过程.例如:将取碗筷、盛饭、盛菜,扒一口饭、夹一筷菜、再扒一口饭、再夹一筷菜的若干重复,然后放下碗筷的过程归并为吃饭.     数据抽象:通俗地说,就是将事物归类,或者说,将事物看成是一定型号、规格的数据,然后将性质接近的数据归纳(抽象)为一类.例如:将圆、三角形、长方形归为形状类. 数据结构 一系列性质相同的数据, 组织成一定的逻辑结构, 并带有自身的一系列操作 例如:整型向量 不同整型值是一系列性质相同的数据;其数据集合存放在向量中,便是组织成线性存储结构;向量自身有创建、复制、扩建、增删、修改等操作,外加排序、查找等算法可以调用.所以,整型向量在语言中是一种具体的数据结构。 抽象编程 通过抽象的方法来减少编程工作量或有效地减轻编程难度称为抽象编程 将问题通过功能分解,各个击破的编程方法(过程化编程)是一种以行为抽象为主的抽象编程 将问题通过实体分析,分层分类地实现抽象数据类型,从而进行简单应用编程(基于对象编程)是一种以数据抽象为主的抽象编程,这种抽象编程,通过数据类型复用,方便编程,方便维护和扩展,其效果比过程化编程更好 编程 语言中没有许多具体的数据类型,要解决实际问题,很大部分工作是要建立数据模式与实际问题的对应,也就是建立抽象数据类型的过程 对象化编程就是基于分层分类的抽象数据类型之具体编程,它能更好地实现数据结构和算法,便是将N.Wirth的程序公式: 程序=算法+数据结构 具体化为: 程序=算法+抽象数据类型 2. 编程质量 ( Programming Quality ) 可读性: 通过使用更好的编程方法可以从本质上改进可读性 通过使用定义良好的算法和语句控制结构,可以局部改进算法的可理解性 通过学习和使用优秀程序员的编码习惯,采用一贯的编码风格,可以增强可读性 注意:高级程序员与初学者对可读性的把握分寸是不同的 易编程性: 只是对采用好的编程方法或更高级语言而言,抽象程度越大,越易编程 对象化编程在抽象数据类型的创建上做了大量的工作,因而赢得了应用程序编写的方便与快捷 安全性: 编程在算法设计上是挖空心思的劳动过程,而在运用语言对之描述上应该潇洒自在:容易表达,不容易出错,运行上更安全。好的编程方法能够帮助程序员实现潇洒编程 抽象数据类型中可以将大量安全代码嵌入其中,从而使应用编程潇洒自在 实现抽象数据类型的过程本身也是使用其他抽象数据类型的应用编程,同样也充满着潇洒与自在 可维护性: 指局部修改不影响系统全局的总体性能,而系统产生的问题通常可以通过局部维护(修改或更换部件)来解决。 模块化编程使程序可拆装,可局部修改,而不影响整体性能与工作,因而可维护性强,过程化编程是将过程模块化,具有一定的可维护性;对象化编程是将数据类型也模块化,从而导致更方便的维护性能 可扩充性: 指系统扩展时,只增加扩展代码,而对原系统的正常运作只作很少的修改甚至不修改 功能扩展的影响: 过程化编程,会涉及多处扩展代码与原系统不和谐所带来的修改 对象化编程,如果是抽象数据类型的功能扩展,则不会影响原系统的正常运行,而只是支持应用程序中增加的一些扩展代码而已;如果是应用程序功能扩展,那是使用抽象数据类型的抽象代码扩展,其修改量比之低级代码要少 效率: 前提:代码量大不等于运行量大 效率除了看速度,还要看损耗,既要考虑编程方便,又要考虑运行性能(时空效率) 1过程化程序代码量少,但对象化程序的代码量相对较多,但不占系统空间 2过程化程序编写安全代码代价大,因而不系统,对象化程序可以方便地在抽象数据类型中嵌入安全代码,从而导致了代码量大的问题,如果让过程化程序达到其安全指标,为此增加的代码量比对象化程序更多 3. 分析Jose’s问题 ( Analysis the Jose’s Problem ) 对每个算法步骤,分而治之: 例如,环链表操作的复杂性,在循环数数中体现 初始化和善后处理都必须由程序员一人承担,工作量大,容易产生错误 对象化分析: 先考虑一些能对应抽象数据类型的实体,如,以小孩为元素的链表类,问题本身也是一个类,然后脱离问题,先来定制类或者重用类,最后基于类型来实现算法(简单得多) 链表类: 它有创建,增加,减少,修改,搜索等操作 问题(Josephus)类: 它有创建,获得胜利者操作 6. 程序维护 ( Program Maintenanc

您可能关注的文档

文档评论(0)

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

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

1亿VIP精品文档

相关文档