软件工程第15章软件维护与再工程.ppt
《软件工程第15章软件维护与再工程.ppt》由会员分享,可在线阅读,更多相关《软件工程第15章软件维护与再工程.ppt(64页珍藏版)》请在第壹文秘上搜索。
1、2 软件演化是指软件在交付以后,对软件进软件演化是指软件在交付以后,对软件进行的一系列活动的总称。行的一系列活动的总称。 软件演化:软件演化:软件的维护软件的维护、软件再工程软件再工程。 软件维护软件维护阶段覆盖了从软件交付使用到软阶段覆盖了从软件交付使用到软件被淘汰为止的整个时期。软件的开发时件被淘汰为止的整个时期。软件的开发时间可能需要一、二年,甚至更短,但它的间可能需要一、二年,甚至更短,但它的使用时间可能要经历几年或几十年。使用时间可能要经历几年或几十年。 再工程再工程的主要目的是为遗留系统转化为可的主要目的是为遗留系统转化为可演化系统提供一条现实可行的途径,是在演化系统提供一条现实可
2、行的途径,是在软件生命周期终止后开始的一个新的阶段。软件生命周期终止后开始的一个新的阶段。 3软件维护软件维护再工程技术再工程技术4再工程技术再工程技术5 什么是软件维护什么是软件维护 是指软件系统交付使用以后,为了改正错误是指软件系统交付使用以后,为了改正错误或满足新的需要而修改软件的过程或满足新的需要而修改软件的过程 国标国标GB/T 11457-2006给出如下定义给出如下定义 在一软件产品交付使用后对其进行修改,以在一软件产品交付使用后对其进行修改,以纠正故障纠正故障; 在一软件产品交付使用后对其进行修改,以在一软件产品交付使用后对其进行修改,以纠正故障、改进其性能和其它属性,或使产纠
3、正故障、改进其性能和其它属性,或使产品适应改变了的环境品适应改变了的环境6 两种两种错误认识错误认识 软件维护是一次新的开发活动软件维护是一次新的开发活动 软件维护就是改错软件维护就是改错 新开发活动新开发活动强调要在一定的约束条件下从强调要在一定的约束条件下从头开始实施头开始实施 软件维护软件维护强调必须在现有系统的限定和约强调必须在现有系统的限定和约束条件下实施束条件下实施 ;根据起因不同,软件维;根据起因不同,软件维护可以分为护可以分为纠错性维护纠错性维护、适应性维护适应性维护、改改善性维护善性维护和和预防性维护预防性维护四类四类 7 纠错性维护纠错性维护:为了改正软件系统中的错误,使:
4、为了改正软件系统中的错误,使软件能够满足预期的正常运行状态的要求而进软件能够满足预期的正常运行状态的要求而进行的维护行的维护 适应性维护适应性维护:为了使软件适应内部或外部环境:为了使软件适应内部或外部环境变化,而去修改软件的过程变化,而去修改软件的过程 改善性维护改善性维护:满足使用过程中用户提出增加新:满足使用过程中用户提出增加新功能或修改已有功能的建议维护功能或修改已有功能的建议维护 预防性维护预防性维护:为了提高软件的可维护性、可靠:为了提高软件的可维护性、可靠性等,为以后进一步改进软件打下良好基础而性等,为以后进一步改进软件打下良好基础而修改软件的活动修改软件的活动8 在实践中,软件
5、维护各种活动常常交织在在实践中,软件维护各种活动常常交织在一起,尽管这些维护在性质上有些重叠,一起,尽管这些维护在性质上有些重叠,但是还是有充分的理由区分这些维护活动但是还是有充分的理由区分这些维护活动 只有正确区分维护活动的类型才能够更有只有正确区分维护活动的类型才能够更有效地确定维护需求的优先级效地确定维护需求的优先级 9 结构化维护结构化维护:采用软件工程的方法进行软件开发,保证:采用软件工程的方法进行软件开发,保证每个阶段都有完整且详细的文档每个阶段都有完整且详细的文档 非结构化维护非结构化维护:如果不采用软件工程方法开发软件,软:如果不采用软件工程方法开发软件,软件只有程序而欠缺文档
6、,则维护工作将变得十分困难件只有程序而欠缺文档,则维护工作将变得十分困难 维护时,开发人员从分析需求规格说明开始,明白软件维护时,开发人员从分析需求规格说明开始,明白软件功能和性能上的改变,对设计说明文档进行修改和复查,功能和性能上的改变,对设计说明文档进行修改和复查,再根据设计修改进行程序变动,并用测试文档中的测试再根据设计修改进行程序变动,并用测试文档中的测试用例进行回归测试,最后将修改后的软件再次交付使用。用例进行回归测试,最后将修改后的软件再次交付使用。10和软件维护有关的部分问题和软件维护有关的部分问题 :理解别人的代码通常是非常困难的,而且理解别人的代码通常是非常困难的,而且难度随
7、着软件配置成分的缺失而迅速增加难度随着软件配置成分的缺失而迅速增加需要维护的软件往往没有文档、或文档资需要维护的软件往往没有文档、或文档资料严重不足、或软件的变化未在相应的文料严重不足、或软件的变化未在相应的文档中反映出来档中反映出来11当软件要求维护时,不能指望由原来的开当软件要求维护时,不能指望由原来的开发人员来完成或提供软件的解释。由于维发人员来完成或提供软件的解释。由于维护持续时间很长,因此当需要解释软件时护持续时间很长,因此当需要解释软件时候,往往开发人员已经不在附近了候,往往开发人员已经不在附近了绝大多数软件在设计时没有考虑到将来的绝大多数软件在设计时没有考虑到将来的修改问题修改问
8、题软件维护这项工作毫无吸引力。一方面是软件维护这项工作毫无吸引力。一方面是因为软件维护,看不到什么因为软件维护,看不到什么“成果成果”,但,但工作量很大,更重要的是维护工作难度大,工作量很大,更重要的是维护工作难度大,软件维护人员经常遭受挫折。软件维护人员经常遭受挫折。 12 软件维护除费用外的无形代价包括软件维护除费用外的无形代价包括 维护活动占用了其他软件开发可用的资源,维护活动占用了其他软件开发可用的资源,使资源的利用率降低使资源的利用率降低 一些修复或修改请求得不到及时安排,使得一些修复或修改请求得不到及时安排,使得客户满意率下降客户满意率下降 维护的结果把一些新的潜在的错误引入软件,



- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 软件工程 15 软件 维护 工程
