C++程序设计教程:第十一章 基于对象编程

上传人:pu****.1 文档编号:570175396 上传时间:2024-08-02 格式:PPT 页数:21 大小:283.50KB
返回 下载 相关 举报
C++程序设计教程:第十一章 基于对象编程_第1页
第1页 / 共21页
C++程序设计教程:第十一章 基于对象编程_第2页
第2页 / 共21页
C++程序设计教程:第十一章 基于对象编程_第3页
第3页 / 共21页
C++程序设计教程:第十一章 基于对象编程_第4页
第4页 / 共21页
C++程序设计教程:第十一章 基于对象编程_第5页
第5页 / 共21页
点击查看更多>>
资源描述

《C++程序设计教程:第十一章 基于对象编程》由会员分享,可在线阅读,更多相关《C++程序设计教程:第十一章 基于对象编程(21页珍藏版)》请在金锄头文库上搜索。

1、13:26:501C+程序设计教程(第二版)第十一章 基于对象编程 Chapter 11 Object-Based Programming13:26:502第十一章内容1.抽象编程抽象编程 ( Abstract Programming )2.编程质量编程质量 ( Programming Quality ) 3.分析分析Joses问题问题 ( Analysis the Joses Problem )4.基于过程的实现基于过程的实现 ( Procedure-Based Solving )5.基于对象的实现基于对象的实现 ( Object-Based Solving )6.程序维护程序维护 ( Pr

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

3、相同的数据一系列性质相同的数据, 组织成一定的逻辑结组织成一定的逻辑结构构, 并带有自身的一系列操作并带有自身的一系列操作例如:整型向量例如:整型向量 不同整型值是一系列性质相同的数据;其数不同整型值是一系列性质相同的数据;其数据集合存放在向量中,便是组织成线性存储据集合存放在向量中,便是组织成线性存储结构;向量自身有创建、复制、扩建、增删、结构;向量自身有创建、复制、扩建、增删、修改等操作,外加排序、查找等算法可以调修改等操作,外加排序、查找等算法可以调用用.所以,整型向量在语言中是一种具体的所以,整型向量在语言中是一种具体的数据结构。数据结构。13:26:505抽象编程抽象编程 通过抽象的

4、方法来减少编程工作量或有效地减轻通过抽象的方法来减少编程工作量或有效地减轻编程难度称为编程难度称为抽象编程抽象编程将问题通过功能分解,各个击破的编程方法将问题通过功能分解,各个击破的编程方法(过过程化编程程化编程)是一种是一种以行为抽象为主的抽象编程以行为抽象为主的抽象编程将问题通过实体分析,分层分类地实现抽象数据将问题通过实体分析,分层分类地实现抽象数据类型,从而进行简单应用编程类型,从而进行简单应用编程(基于对象编程基于对象编程)是一种是一种以数据抽象为主的抽象编程以数据抽象为主的抽象编程,这种抽,这种抽象编程,通过数据类型复用,方便编程,方便象编程,通过数据类型复用,方便编程,方便维护和

5、扩展,其效果比过程化编程更好维护和扩展,其效果比过程化编程更好13:26:516编程编程 语言中没有许多具体的数据类型,要解决实际问语言中没有许多具体的数据类型,要解决实际问题,很大部分工作是要建立数据模式与实际问题,很大部分工作是要建立数据模式与实际问题的对应,也就是建立抽象数据类型的过程题的对应,也就是建立抽象数据类型的过程对象化编程就是基于分层分类的抽象数据类型的对象化编程就是基于分层分类的抽象数据类型的具体编程,它能更好地实现数据结构和算法,具体编程,它能更好地实现数据结构和算法,便是将便是将N.Wirth提出的经典的程序公式:提出的经典的程序公式: 程序程序=算法算法+数据结构数据结

6、构修正为:修正为: 程序程序=算法算法+抽象数据类型抽象数据类型13:26:5172. 编程质量编程质量 ( Programming Quality ) 可读性:l通过使用更好的编程方法可以从本质上改进可读性l通过使用定义良好的算法和语句控制结构,可以局部改进算法的可理解性l通过学习和使用优秀程序员的编码习惯,采用一贯的编码风格,可以增强可读性l注意:高级程序员与初学者对可读性的把握分寸是不同的 13:26:518While(*s+ = *t+); /代码1While( *t ) /代码2*s = *t;s+;t+; *s=0;13:26:519易编程性:只是对采用好的编程方法或更高级语言而言

7、,抽象程度越大,越易编程对象化编程在抽象数据类型的创建上做了大量的工作,因而赢得了应用程序编写的方便与快捷13:26:5110void f( int a,vector & b)int c10 = a;vectord = b;void f(int n)int an;for(int i =0;i ai;13:26:5111void f(int n)int *ap = new intn;for(int i =0;i api;delete ap;void f(int n)vector a(n);for(int i =0;i ai;13:26:5112安全性:编程在算法设计上是挖空心思的劳动过程,而在运

8、用语言对之描述上应该潇洒自在:容易表达,不容易出错,运行上更安全。好的编程方法能够帮助程序员实现潇洒编程抽象数据类型中可以将大量安全代码嵌入其中,从而使应用编程潇洒自在实现抽象数据类型的过程本身也是使用其他抽象数据类型的应用编程,同样也充满着潇洒与自在13:26:5113void f(char *s)string s1,s2=s;s1 = s;char *st = new char(strlen(s)+1);strcpy(st,s);char a40;strncpy(a,s);void g()char *str = “hello world”;f(str);13:26:5114可维护性:指局部

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

10、类型的抽象代码扩展,其修改量比之低级代码要少13:26:5116效率:前提:代码量大不等于运行量大效率除了看速度,还要看损耗,既要考虑编程方便,又要考虑运行性能(时空效率)1过程化程序代码量少,但对象化程序的代码量相对较多,但不占系统空间2过程化程序编写安全代码代价大,因而不系统,对象化程序可以方便地在抽象数据类型中嵌入安全代码,从而导致了代码量大的问题,如果让过程化程序达到其安全指标,为此增加的代码量比对象化程序更多13:26:51173. 分析分析Joses问题问题 ( Analysis the Joses Problem )过程化分析:按实现过程分析,功能划分,从而得到几个算法步骤:获得

11、小孩数n,开始位置s,间隔数m创建环链表循环数数,排除n-1个小孩输出剩下的小孩编号(胜利者)善后工作(清除环链表)13:26:5118对每个算法步骤,分而治之:例如,环链表操作的复杂性,在循环数数中体现初始化和善后处理都必须由程序员一人承担,工作量大,容易产生错误13:26:5119对象化分析:先考虑一些能对应抽象数据类型的实体,如,以小孩为元素的链表类,问题本身也是一个类,然后脱离问题,先来定制类或者重用类,最后基于类型来实现算法(简单得多)链表类:它有创建,增加,减少,修改,搜索等操作问题(Josephus)类:它有创建,获得胜利者操作13:26:51206. 程序维护程序维护 ( Pr

12、ogram Maintenance )维护要求:将上述Josephus问题进行扩展,使之能够实现求解若干个胜利者的功能,但同时要求保留原来的求解一个获胜者的功能。为了实现上述扩展功能,都是在Josephus类中暗中完成的,所以只要修改Josephus类的 getWinner成员函数,而无须修改应用程序,便可达到维护好系统的目的13:26:51217. 程序扩展程序扩展 ( Program Extension )扩展要求既要求直接数m个数,最后所获得的1个胜利者,也要求按维护要求的数法所获得的多个胜利者。但原来类的定义要求维持原状。此时,便要保留原来的求胜利者的成员函数,再设计实现一个成员函数,作为功能扩展,再在原系统中增加调用该成员函数的语句。由于小孩转圈的结构没有变,所以该扩展要求就不涉及链表修改

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 高等教育 > 研究生课件

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号