复旦大学《软件工程》钱乐秋课件教案ppt13

上传人:cjc****537 文档编号:49674498 上传时间:2018-08-01 格式:PPT 页数:68 大小:187KB
返回 下载 相关 举报
复旦大学《软件工程》钱乐秋课件教案ppt13_第1页
第1页 / 共68页
复旦大学《软件工程》钱乐秋课件教案ppt13_第2页
第2页 / 共68页
复旦大学《软件工程》钱乐秋课件教案ppt13_第3页
第3页 / 共68页
复旦大学《软件工程》钱乐秋课件教案ppt13_第4页
第4页 / 共68页
复旦大学《软件工程》钱乐秋课件教案ppt13_第5页
第5页 / 共68页
点击查看更多>>
资源描述

《复旦大学《软件工程》钱乐秋课件教案ppt13》由会员分享,可在线阅读,更多相关《复旦大学《软件工程》钱乐秋课件教案ppt13(68页珍藏版)》请在金锄头文库上搜索。

1、软件工程第13章软件维护与再工程1复旦大学计算机科学与工程系 软件工程课程 软件演化是指软件在交付以后,对软件 进行的一系列活动的总称。 软件演化:软件的维护、软件再工程。 软件维护阶段覆盖了从软件交付使用到 软件被淘汰为止的整个时期。软件的开 发时间可能需要一、二年,甚至更短, 但它的使用时间可能要经历几年或几十 年。 再工程的主要目的是为遗留系统转化为 可演化系统提供一条现实可行的途径, 是在软件生命周期终止后开始的一个新 的阶段。 2复旦大学计算机科学与工程系 软件工程课程内容摘要 软件维护 再工程技术3复旦大学计算机科学与工程系 软件工程课程内容摘要 软件维护软件维护 再工程技术4复旦

2、大学计算机科学与工程系 软件工程课程软件维护的概念 什么是软件维护 是指软件系统交付使用以后,为了改正错 误或满足新的需要而修改软件的过程 国标GB/T 11457-95给出如下定义 在一软件产品交付使用后对其进行修改, 以纠正故障; 在一软件产品交付使用后对其进行修改, 以纠正故障、改进其性能和其它属性,或 使产品适应改变了的环境5复旦大学计算机科学与工程系 软件工程课程软件维护的概念软件维护分类 两种错误认识 软件维护是一次新的开发活动 软件维护就是改错 新开发活动强调要在一定的约束条件下 从头开始实施 软件维护强调必须在现有系统的限定和 约束条件下实施 ;根据起因不同,软件 维护可以分为

3、纠错性维护、适应性维护 、改善性维护和预防性维护四类 6复旦大学计算机科学与工程系 软件工程课程软件维护的概念软件维护分类 纠错性维护:为了改正软件系统中的错误,使 软件能够满足预期的正常运行状态的要求而进 行的维护 适应性维护:为了使软件适应内部或外部环境 变化,而去修改软件的过程 改善性维护:满足使用过程中用户提出增加新 功能或修改已有功能的建议维护 预防性维护:为了提高软件的可维护性、可靠 性等,为以后进一步改进软件打下良好基础而 修改软件的活动7复旦大学计算机科学与工程系 软件工程课程软件维护的概念软件维护分类 在实践中,软件维护各种活动常常交织 在一起,尽管这些维护在性质上有些重 叠

4、,但是还是有充分的理由区分这些维 护活动 只有正确区分维护活动的类型才能够更 有效地确定维护需求的优先级 8复旦大学计算机科学与工程系 软件工程课程软件维护的概念维护问题 结构化维护:采用软件工程的方法进行软件开发,保 证每个阶段都有完整且详细的文档 非结构化维护:如果不采用软件工程方法开发软件, 软件只有程序而欠缺文档,则维护工作将变得十分困 难维护时,开发人员从分析需求规格说明开始,明白软 件功能和性能上的改变,对设计说明文档进行修改和 复查,再根据设计修改进行程序变动,并用测试文档 中的测试用例进行回归测试,最后将修改后的软件再 次交付使用。9复旦大学计算机科学与工程系 软件工程课程软件

5、维护的概念维护问题和软件维护有关的部分问题 : 理解别人的代码通常是非常困难的,而且 难度随着软件配置成分的缺失而迅速增加 需要维护的软件往往没有文档、或文档资 料严重不足、或软件的变化未在相应的文 档中反映出来10复旦大学计算机科学与工程系 软件工程课程软件维护的概念维护问题 当软件要求维护时,不能指望由原来的开 发人员来完成或提供软件的解释。由于维 护持续时间很长,因此当需要解释软件时 候,往往开发人员已经不在附近了 绝大多数软件在设计时没有考虑到将来的 修改问题 软件维护这项工作毫无吸引力。一方面是 因为软件维护,看不到什么“成果”,但工作 量很大,更重要的是维护工作难度大,软 件维护人

6、员经常遭受挫折。 11复旦大学计算机科学与工程系 软件工程课程软件维护的概念维护成本 软件维护除费用外的无形代价包括 维护活动占用了其他软件开发可用的资源 ,使资源的利用率降低 一些修复或修改请求得不到及时安排,使 得客户满意率下降 维护的结果把一些新的潜在的错误引入软 件,降低了软件质量 将软件人员抽调到维护工作中,使得其它 软件开发过程受到干扰 12复旦大学计算机科学与工程系 软件工程课程软件维护的概念维护成本 维护的工作可划分成: 生产性活动 如,分析评价、修改设计、编 写程序代码等 非生产性活动 如,程序代码功能理解、数 据结构解释、接口特点和性能界限分析等 维护工作量的模型 M:维护

7、的总工作量 ;P:生产性工作量;K:经验常数;c :复杂程度;d:维护人员对软件的熟悉程度 13复旦大学计算机科学与工程系 软件工程课程软件维护的概念维护成本 影响维护工作量的因素主要有以下六种 系统的规模:系统规模越大,其功能就越 复杂,软件维护的工作量也随之增大 程序设计语言:使用强功能的程序设计语 言可以控制程序的规模。语言的功能越强 ,生成程序的模块化和结构化程度越高, 所需的指令数就越少,程序的可读性也越 好14复旦大学计算机科学与工程系 软件工程课程软件维护的概念维护成本 系统年龄:老系统比新系统需要更多的维 护工作量。 数据库技术的应用:使用数据库,可以简 单而有效地管理和存储用

8、户程序中的数据 ,还可以减少生成用户报表应用软件的维 护工作量 先进的软件开发技术:在软件开发过程中 ,如果采用先进的分析设计技术和程序设 计技术,如面向对象技术、复用技术等, 可减少大量的维护工作量15复旦大学计算机科学与工程系 软件工程课程软件维护的概念维护成本 其它一些因素:如应用的类型、数学模 型、任务的难度、IF嵌套深度、索引或 下标数等,对维护工作量也有影响 16复旦大学计算机科学与工程系 软件工程课程软件维护的过程维护组织 维护组织结构图 17复旦大学计算机科学与工程系 软件工程课程软件维护的过程维护组织 系统监督员一般都是对程序(某一部分) 特别熟悉的技术人员。 在维护人员对程

9、序进行修改的过程中, 由配置管理员严格把关,控制修改的范 围,对软件配置进行审计 。 维护管理员、系统监督员、修改控制决 策机构等,均代表维护工作的某个职责 范围 。 18复旦大学计算机科学与工程系 软件工程课程软件维护的过程维护组织 修改控制决策机构、维护管理员可以是 指定的某个人,也可以是一个包括管理 人员、高级技术人员在内的小组。 系统监督员可以有其他职责,但应具体 分管某一个软件包。 19复旦大学计算机科学与工程系 软件工程课程软件维护的过程维护组织 维护团队根据时间的不同,可以分为短期 团队和长期团队 短期团队一般是当需要执行相关具体任 务时,临时组织起来解决手头的问题 长期团队则更

10、正式,能够专业化创建沟 通渠道,可以管理软件系统整个生存期 的成功演化 无论是短期团队还是长期团队,都要把 有经验的员工和新员工混合起来。20复旦大学计算机科学与工程系 软件工程课程软件维护的过程维护过程 对于非纠错性维护,则首先判断维护类型,对 适应性维护,按照评估后得到的优先级放入队 列 对于改善性维护,则还要考虑是否采取行动, 如果接受申请,则同样按照评估后得到的优先 级放入队列,如果拒绝申请,则通知请求者, 并说明原因 对于工作安排队列中的任务,由修改负责人依 次从队列中取出任务,按照软件工程方法学规 划、组织、实施工程。21复旦大学计算机科学与工程系 软件工程课程软件维护的过程维护过

11、程维护请求类型类型严重性评估后按优先 级在队列排队救火行动,当 排在队列之首评估后分类评估后按优先 级在队列排队采取的行动通知请求者 并说明原因按优先级在 队列中排队从维护请求队列之首取出一任务按SE方法学规划、组织、实施工程队列中还有维护请求吗?资源用于开发新的软件。yn纠错性维护其他改善性维护适应性维护拒绝接受并不严重非常严重维护过程图22复旦大学计算机科学与工程系 软件工程课程软件维护的过程维护过程 每种维护请求都要进行同样的一系列技 术工作:修改软件需求说明、修改软件 设计、设计评审、必要时重新编码、单 元测试、集成测试( 包括回归测试)、确 认测试等 维护工作最后一步是复审 依照当前

12、状态,在设计、编码和测试的哪 些方面还能用其他方法进行? 哪些维护资源可用但未用?23复旦大学计算机科学与工程系 软件工程课程软件维护的过程维护过程 这次维护活动中主要(或次要)的障碍有哪些 ? 在维护请求中有预防性维护吗?24复旦大学计算机科学与工程系 软件工程课程软件维护的过程维护记录 维护人员对程序进行修改前要着重做好两个记 录 维护申请报告 软件修改报告 维护请求表(报告)即软件问题报告,该报告 (表)由要求一项维护活动的用户填写。对改 正性维护,用户需要将错误出现的现场信息详 细描述出来,包括输入数据、错误清单以及其 它有关材料。对适应性维护或改善性维护,应 该给出一个简短的需求规格

13、说明书。维护申请 被批准后,维护申请报告就成为外部文档,作 为本次维护的依据 25复旦大学计算机科学与工程系 软件工程课程软件维护的过程维护记录 软件修改报告指明:为满足维护申请报 告提出的需求所需的工作量、本次维护 活动的类别、本次维护请求的优先级、 本次修改的背景数据。在拟定进一步维 护计划前,软件修改报告要提交给修改 决策机构,供进一步规划维护活动使用 保存维护记录的第一个问题就是哪些数 据值得保存?26复旦大学计算机科学与工程系 软件工程课程软件维护的过程维护评价 如果已经开始保存维护记录,可以对维护工作 做一些定量度量,至少可以从如下7方面进行 评价: 每次程序运行平均失败的次数;

14、用于每一类维护活动的总人时数; 平均每个程序、每种语言、每种维护类型所必需的 程序变动数; 维护过程中增加或删除源语句平均花费的人时数; 维护每种语言平均花费的人时数; 一张维护请求表的平均周转时间; 不同维护类型所占的比例;27复旦大学计算机科学与工程系 软件工程课程软件可维护性 可维护性(maintainability) 指理解、改正、调整和改进软件的难易程 度。对软件可维护性影响的主要因素有: 可理解性(understandability)、可测试 性(testability)、可修改性、 modifiability)和可移植性(portability ) 28复旦大学计算机科学与工程系

15、 软件工程课程软件可维护性主要影响因素 可理解性:指理解软件的结构、接口、 功能和内部过程的难易程度。 提高软件可理解性的措施有:采用模块 化的程序结构;书写详细正确的文档; 采用结构化程序设计;书写源程序的内 部文档;使用良好的编程语言;具有良 好的程序设计风格等 29复旦大学计算机科学与工程系 软件工程课程软件可维护性主要影响因素 可测试性:指测试和诊断软件(主要指 程序)中错误的难易程度。 提高软件可测试性的措施有:采用良好 的程序结构;书写详细正确的文档;使 用测试工具和调试工具;保存以前的测 试过程和测试用例等 30复旦大学计算机科学与工程系 软件工程课程软件可维护性主要影响因素 可修改性:指修改软件(主要指程序) 的难易程度。 在修改软件时经常会发生这样的情况: 修改了程序中某个错误的同时又产生新 的错误(由程序的修改引起的);或者 在程序中增加了某个功能后,导致原先 的某些功能不能正常执行。 31复旦大学计算机科学与工程系 软件工程课程软件可维护性主要影响因素 可移植性:指程序转移到一个新的计算环境的 难易程度。 影响软件可移植性的因素有:信息隐蔽原则; 模块独立;模块化;高内聚低耦合;良好的程 序结构;不用标准文本以外的语句等 一个可移植的程序应具有结构良好、灵活、不 依赖于某一具体计算机或操作系统的性能 32复旦

展开阅读全文
相关资源
相关搜索

当前位置:首页 > IT计算机/网络 > 计算机应用/办公自动化

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