钱能C++程序设计教程11.ppt_第1页
钱能C++程序设计教程11.ppt_第2页
钱能C++程序设计教程11.ppt_第3页
钱能C++程序设计教程11.ppt_第4页
钱能C++程序设计教程11.ppt_第5页
已阅读5页,还剩12页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、08:53:28,1,C+程序设计教程(第二版),第十一章 基于对象编程 Chapter 11 Object-Based Programming,清华大学出版社 钱 能,08:53:28,2,第十一章内容,抽象编程 ( Abstract Programming ) 编程质量 ( Programming Quality ) 分析Joses问题 ( Analysis the Joses Problem ) 基于过程的实现 ( Procedure-Based Solving ) 基于对象的实现 ( Object-Based Solving ) 程序维护 ( Program Maintenance )

2、 程序扩展 ( Program Extension ),08:53:28,3,1. 抽象编程 ( Abstract Programming ),抽象分行为抽象和数据抽象两种 行为抽象:通俗地说便是将一个行为序列归并(抽象)为一个行为的过程.例如:将取碗筷、盛饭、盛菜,扒一口饭、夹一筷菜、再扒一口饭、再夹一筷菜的若干重复,然后放下碗筷的过程归并为吃饭. 数据抽象:通俗地说,就是将事物归类,或者说,将事物看成是一定型号、规格的数据,然后将性质接近的数据归纳(抽象)为一类.例如:将圆、三角形、长方形归为形状类.,08:53:28,4,数据结构,一系列性质相同的数据, 组织成一定的逻辑结构, 并带有自

3、身的一系列操作 例如:整型向量 不同整型值是一系列性质相同的数据;其数据集合存放在向量中,便是组织成线性存储结构;向量自身有创建、复制、扩建、增删、修改等操作,外加排序、查找等算法可以调用.所以,整型向量在语言中是一种具体的数据结构。,08:53:28,5,抽象编程,通过抽象的方法来减少编程工作量或有效地减轻编程难度称为抽象编程 将问题通过功能分解,各个击破的编程方法(过程化编程)是一种以行为抽象为主的抽象编程 将问题通过实体分析,分层分类地实现抽象数据类型,从而进行简单应用编程(基于对象编程)是一种以数据抽象为主的抽象编程,这种抽象编程,通过数据类型复用,方便编程,方便维护和扩展,其效果比过

4、程化编程更好,08:53:28,6,编程,语言中没有许多具体的数据类型,要解决实际问题,很大部分工作是要建立数据模式与实际问题的对应,也就是建立抽象数据类型的过程 对象化编程就是基于分层分类的抽象数据类型之具体编程,它能更好地实现数据结构和算法,便是将N.Wirth的程序公式: 程序=算法+数据结构 具体化为: 程序=算法+抽象数据类型,08:53:28,7,2. 编程质量 ( Programming Quality ),可读性: 通过使用更好的编程方法可以从本质上改进可读性 通过使用定义良好的算法和语句控制结构,可以局部改进算法的可理解性 通过学习和使用优秀程序员的编码习惯,采用一贯的编码风

5、格,可以增强可读性 注意:高级程序员与初学者对可读性的把握分寸是不同的,08:53:28,8,易编程性: 只是对采用好的编程方法或更高级语言而言,抽象程度越大,越易编程 对象化编程在抽象数据类型的创建上做了大量的工作,因而赢得了应用程序编写的方便与快捷,08:53:28,9,安全性: 编程在算法设计上是挖空心思的劳动过程,而在运用语言对之描述上应该潇洒自在:容易表达,不容易出错,运行上更安全。好的编程方法能够帮助程序员实现潇洒编程 抽象数据类型中可以将大量安全代码嵌入其中,从而使应用编程潇洒自在 实现抽象数据类型的过程本身也是使用其他抽象数据类型的应用编程,同样也充满着潇洒与自在,08:53:

6、28,10,可维护性: 指局部修改不影响系统全局的总体性能,而系统产生的问题通常可以通过局部维护(修改或更换部件)来解决。 模块化编程使程序可拆装,可局部修改,而不影响整体性能与工作,因而可维护性强,过程化编程是将过程模块化,具有一定的可维护性;对象化编程是将数据类型也模块化,从而导致更方便的维护性能,08:53:28,11,可扩充性: 指系统扩展时,只增加扩展代码,而对原系统的正常运作只作很少的修改甚至不修改 功能扩展的影响: 过程化编程,会涉及多处扩展代码与原系统不和谐所带来的修改 对象化编程,如果是抽象数据类型的功能扩展,则不会影响原系统的正常运行,而只是支持应用程序中增加的一些扩展代码

7、而已;如果是应用程序功能扩展,那是使用抽象数据类型的抽象代码扩展,其修改量比之低级代码要少,08:53:28,12,效率: 前提:代码量大不等于运行量大 效率除了看速度,还要看损耗,既要考虑编程方便,又要考虑运行性能(时空效率) 1过程化程序代码量少,但对象化程序的代码量相对较多,但不占系统空间 2过程化程序编写安全代码代价大,因而不系统,对象化程序可以方便地在抽象数据类型中嵌入安全代码,从而导致了代码量大的问题,如果让过程化程序达到其安全指标,为此增加的代码量比对象化程序更多,08:53:28,13,3. 分析Joses问题 ( Analysis the Joses Problem ),过程

8、化分析:按实现过程分析,功能划分,从而得到几个算法步骤:获得小孩数n,开始位置s,间隔数m创建环链表循环数数,排除n-1个小孩输出剩下的小孩编号(胜利者)善后工作(清除环链表),08:53:28,14,对每个算法步骤,分而治之:例如,环链表操作的复杂性,在循环数数中体现初始化和善后处理都必须由程序员一人承担,工作量大,容易产生错误,08:53:28,15,对象化分析:先考虑一些能对应抽象数据类型的实体,如,以小孩为元素的链表类,问题本身也是一个类,然后脱离问题,先来定制类或者重用类,最后基于类型来实现算法(简单得多)链表类:它有创建,增加,减少,修改,搜索等操作问题(Josephus)类:它有创建,获得胜利者操作,08:53:28,16,6. 程序维护 ( Program Maintenance ),维护要求: 数个数m,m若改为根据当前小孩的序号与m的和来确定个数m,则在进行数个数前,先要进行表达式计算, 这一切,都是在Josephus类中暗中完成的,所以只要修改Josephus类的 getWinner 无须修改应用程序,便可维护好系统,08:53:28,17,7. 程序扩展 ( Program Extensio

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论