首页 8.软件工程 维护

8.软件工程 维护

举报
开通vip

8.软件工程 维护null维护 维护 维护维护8.1 软件维护的定义 8.2 软件维护的特点 8.3 软件维护过程 8.4 软件的可维护性 8.5 预防性维护 8.6 软件再工程过程 8.7 小结 null维护阶段是软件生命周期的最后一个阶段,其基本任务是保证软件在一个相当长的时期能够正常运行。 软件维护需要的工作量很大,平均说来,大型软件的维护成本高达开发成本的4倍左右。目前国外许多软件开发组织把60%以上的人力用于维护已有的软件,而且随着软件数量增多和使用寿命延长,这个百分比还在持续上升。 软件工程的目的是要提...

8.软件工程 维护
null维护 维护 维护维护8.1 软件维护的定义 8.2 软件维护的特点 8.3 软件维护过程 8.4 软件的可维护性 8.5 预防性维护 8.6 软件再工程过程 8.7 小结 null维护阶段是软件生命周期的最后一个阶段,其基本任务是保证软件在一个相当长的时期能够正常运行。 软件维护需要的工作量很大,平均说来,大型软件的维护成本高达开发成本的4倍左右。目前国外许多软件开发组织把60%以上的人力用于维护已有的软件,而且随着软件数量增多和使用寿命延长,这个百分比还在持续上升。 软件工程的目的是要提高软件的可维护性,减少软件维护所需要的工作量,降低软件系统的总成本。8.1 软件维护的定义8.1 软件维护的定义软件维护就是在软件已经交付使用之后,为了改正错误或满足新的需要而修改软件的过程。 有4项活动,具体地定义软件维护: 改正性维护 适应性维护 完善性维护 预防性维护 null软件维护绝不仅限于纠正使用中发现的错误,在全部维护活动中一半以上是完善性维护。 国外的统计数字表明,完善性维护占全部维护活动的50%~66%,改正性维护占17%~21%,适应性维护占18%~25%,其他维护活动只占4%左右。 上述4类维护活动都必须应用于整个软件配置,维护软件文档和维护软件的可执行代码是同样重要的。8.2 软件维护的特点 8.2 软件维护的特点 结构化维护 非结构化维护 结构化维护与非结构化维护差别巨大null非结构化维护 如果软件配置的惟一成分是程序代码: 那么维护活动从艰苦地评价程序代码开始 常常由于程序内部文档不足而使评价更困难 对于软件结构、全程数据结构、系统接口、性能和(或) 设计 领导形象设计圆作业设计ao工艺污水处理厂设计附属工程施工组织设计清扫机器人结构设计 约束等经常会产生误解 对程序代码所做的改动的后果也是难于估量的 因为没有测试方面的文档,所以不可能进行回归测试 非结构化维护需要付出很大代价(浪费精力并且遭受挫折的打击) 这种维护方式是没有使用良好定义的方法学开发出来的软件的必然结果。null结构化维护 如果有一个完整的软件配置存在: 那么维护工作从评价设计文档开始,确定软件重要的结构特点、性能特点以及接口特点; 估量要求的改动将带来的影响,并且计划实施途径。 然后首先修改设计并且对所做的修改进行仔细复查。 接下来编写相应的源程序代码; 使用在测试 说明书 房屋状态说明书下载罗氏说明书下载焊机说明书下载罗氏说明书下载GGD说明书下载 中包含的信息进行回归测试; 最后,把修改后的软件再次交付使用。 这是在软件开发的早期应用软件工程方法学的结果。 虽然有了软件的完整配置并不能保证维护中没有问题,但是确实能减少精力的浪费并且能提高维护的总体质量。8.2.2 维护的代价高昂8.2.2 维护的代价高昂在过去的几十年中,软件维护的费用稳步上升。 1970年用于维护已有软件的费用只占软件总预算的35%~40% 1980年上升为40%~60% 1990年上升为70%~80%。 维护费用只不过是软件维护的最明显的代价,其他一些现在还不明显的代价将来可能更为人们所关注。 因为可用的资源必须供维护任务使用,以致耽误甚至丧失了开发的良机,这是软件维护的一个无形的代价。null用于维护工作的劳动可以分成生产性活动(例如,分析评价,修改设计和编写程序代码等)和非生产性活动(例如,理解程序代码的功能,解释数据结构、接口特点和性能限度等)。 下述表达式给出维护工作量的一个模型: M=P+K×exp(c-d) 其中: M是维护用的总工作量,P是生产性工作量,K是经验常数,c是复杂程度(非结构化设计和缺少文档都会增加软件的复杂程度),d是维护人员对软件的熟悉程度。 上面的模型表明,如果软件的开发途径不好(即,没有使用软件工程方法学),而且原来的开发人员不能参加维护工作,那么维护工作量和费用将指数地增加。8.2.3 维护的问题很多8.2.3 维护的问题很多与软件维护有关的绝大多数问题,都可归因于软件定义和软件开发的方法有缺点。在软件生命周期的头两个时期没有严格而又科学的管理和规划 下面列出和软件维护有关的部分问题: (1) 理解别人写的程序通常非常困难,而且困难程度随着软件配置成分的减少而迅速增加。如果仅有程序代码没有说明文档,则会出现严重的问题。 (2) 需要维护的软件往往没有合格的文档,或者文档资料显著不足。认识到软件必须有文档仅仅是第一步,容易理解的并且和程序代码完全一致的文档才真正有价值。null (3) 当要求对软件进行维护时,不能指望由开发人员给我们仔细说明软件。 (4) 绝大多数软件在设计时没有考虑将来的修改。除非使用强调模块独立原理的设计方法学,否则修改软件既困难又容易发生差错。 (5) 软件维护不是一项吸引人的工作。形成这种观念很大程度上是因为维护工作经常遭受挫折。 软件工程至少部分地解决了与维护有关的每一个问题。8.3 软件维护过程8.3 软件维护过程维护过程本质上是修改和压缩了的软件定义和开发过程 必须建立一个维护组织,随后必须确定报告和评价的过程,而且必须为每个维护要求规定一个 标准 excel标准偏差excel标准偏差函数exl标准差函数国标检验抽样标准表免费下载红头文件格式标准下载 化的事件序列。此外,还应该建立一个适用于维护活动的记录保管过程,并且规定复审标准。null维护组织 通常并不需要建立正式的维护组织,但是,非正式地委托责任也是绝对必要的。 每个维护要求都通过维护管理员转交给相应的系统管理员去评价。 系统管理员是被指定去熟悉一小部分产品程序的技术人员。 系统管理员对维护任务做出评价之后,由变化授权人决定应该进行的活动。 在维护活动开始之前就明确维护责任是十分必要的,这样做可以大大减少维护过程中可能出现的混乱。null 图8.1 维护组织null维护报告 用标准化的格式表达所有软件维护要求。 软件维护人员给用户提供空白的维护要求表——软件问题报告表,这个表格由要求一项维护活动的用户填写。 如果遇到了一个错误,那么必须完整描述导致出现错误的环境(包括输入数据、全部输出数据以及其他有关信息)。 对于适应性或完善性的维护要求,应该提出一个简短的需求说明 关于书的成语关于读书的排比句社区图书漂流公约怎么写关于读书的小报汉书pdf 。 由维护管理员和系统管理员评价用户提交的维护要求表。null维护要求表是一个外部产生的文件,它是计划维护活动的基础。 软件组织内部应该制定出一个软件修改报告,它给出下述信息: (1) 满足维护要求表中提出的要求所需要的工作量; (2) 维护要求的性质; (3) 这项要求的优先次序; (4) 与修改有关的事后数据。 在拟定进一步的维护计划之前,把软件修改报告提交给变化授权人审查批准。null维护的事件流 图8.2描绘了由一项维护要求而引出的一串事件。 首先应该确定要求进行的维护的类型。用户常常把一项要求看作是为了改正软件的错误(改正性维护),而开发人员可能把同一项要求看作是适应性或完善性维护。当存在不同意见时必须协商解决。null 图8.2 维护阶段的事件流null保存维护记录 对于软件生命周期的所有阶段而言,以前记录保存都是不充分的,而软件维护则根本没有记录保存下来。 由于这个原因,往往不能估价维护技术的有效性,不能确定一个产品程序的“优良”程度,而且很难确定维护的实际代价是什么。null评价维护活动 缺乏有效的数据就无法评价维护活动。 如果已经开始保存维护记录了,则可以对维护工作做一些定量度量。至少可以从下述7个方面度量维护工作: (1) 每次程序运行平均失效的次数; (2) 用于每一类维护活动的总人时数; (3) 平均每个程序、每种语言、每种维护类型所做的程序变动数;null(4) 维护过程中增加或删除一个源语句平均花费的人时数; (5) 维护每种语言平均花费的人时数; (6) 一张维护要求表的平均周转时间; (7) 不同维护类型所占的百分比。 根据对维护工作定量度量的结果,可以做出关于开发技术、语言选择、维护工作量规划、资源分配及其他许多方面的决定,而且可以利用这样的数据去分析评价维护任务。8.4 软件的可维护性8.4 软件的可维护性可以把软件的可维护性定性地定义为: 维护人员理解、改正、改动或改进这个软件的难易程度。 提高可维护性是支配软件工程方法学所有步骤的关键目标。8.4.1 决定软件可维护性的因素8.4.1 决定软件可维护性的因素维护就是在软件交付使用后进行的修改 修改之前必须理解待修改的对象 修改之后应该进行必要的测试,以保证所做的修改是正确的 如果是改正性维护,还必须预先进行调试以确定错误的具体位置 因此,决定软件可维护性的因素主要有下述5个:null 可理解性 可测试性 可修改性 可移植性 可重用性 8.4.2 文档8.4.2 文档文档是影响软件可维护性的决定因素。 由于长期使用的大型软件系统在使用过程中必然会经受多次修改,所以文档比程序代码更重要。 软件系统的文档可以分为用户文档和系统文档两类。 用户文档主要描述系统功能和使用方法,并不关心这些功能是怎样实现的; 系统文档描述系统设计、实现和测试等各方面的内容。null 总的说来,软件文档应该满足下述要求: (1) 必须描述如何使用这个系统; (2) 必须描述怎样安装和管理这个系统; (3) 必须描述系统需求和设计; (4) 必须描述系统的实现和测试,以便使系统成为可维护的。 下面分别讨论用户文档和系统文档。null1. 用户文档 用户文档是用户了解系统的第一步,它应该能使用户获得对系统的准确的初步印象。 文档的结构方式应该使用户能够方便地根据需要阅读有关的内容。 用户文档至少应该包括下述5方面的内容: (1) 功能描述,说明系统能做什么; (2) 安装文档,说明怎样安装这个系统以及怎样使系统适应特定的硬件配置; (3) 使用手册(应该通过丰富例子说明怎样使用常用的系统功能) (4)参考手册(对参考手册最主要的要求是完整) (5)操作员指南(如果需要有系统操作员的话)null2. 系统文档 所谓系统文档指从问题定义、需求说明到验收测试计划这样一系列和系统实现有关的文档。 描述系统设计、实现和测试的文档对于理解程序和维护程序来说是极端重要的。 和用户文档类似,系统文档的结构也应该能把读者从对系统概貌的了解,引导到对系统每个方面每个特点的更形式化更具体的认识。8.4.3 可维护性复审8.4.3 可维护性复审可维护性是所有软件都应该具备的基本特点,必须在开发阶段保证软件具有8.4.1节中提到的那些可维护因素。 在软件工程过程的每一个阶段都应该考虑并努力提高软件的可维护性,在每个阶段结束前的技术审查和管理复审中,应该着重对可维护性进行复审。 在需求分析阶段的复审过程中,应该对将来要改进的部分和可能会修改的部分加以注意并指明;应该讨论软件的可移植性问题,并且考虑可能影响软件维护的系统界面。8.5 预防性维护8.5 预防性维护几乎所有历史比较悠久的软件开发组织,都有一些十几年前开发出的“老”程序。 目前,某些老程序仍然在为用户服务,但是,当初开发这些程序时并没有使用软件工程方法学来指导 因此,这些程序的体系结构和数据结构都很差,文档不全甚至完全没有文档,对曾经做过的修改也没有完整的记录。 为了修改这类程序以适应用户新的或变更的需求,有以下几种做法可供选择:null(1) 反复多次地做修改程序的尝试,与不可见的设计及源代码“顽强战斗”,以实现所要求的修改; (2) 通过仔细分析程序尽可能多地掌握程序的内部工作细节,以便更有效地修改它; (3) 在深入理解原有设计的基础上,用软件工程方法重新设计、重新编码和测试那些需要变更的软件部分; (4) 以软件工程方法学为指导,对程序全部重新设计、重新编码和测试,为此可以使用CASE工具(逆向工程和再工程工具)来帮助理解原有的设计。null第一种做法很盲目,通常人们采用后3种做法。 其中第4种做法称为软件再工程,这样的维护活动也就是本章8.1节中所说的预防性维护 而第3种做法实质上是局部的再工程。 预防性维护方法是由Miller提出来的,他把这种方法定义为:“把今天的方法学应用到昨天的系统上,以支持明天的需求。” null是浪费吗? (1) 维护一行源代码的代价可能是最初开发该行源代码代价的14~40倍; (2) 重新设计软件体系结构(程序及数据结构)时使用了现代设计概念,对将来的维护可能有很大的帮助; (3) 由于现有的程序版本可作为软件原型使用,开发生产率可大大高于平均水平; (4) 用户具有较多使用该软件的经验,因此,能够很容易地搞清新的变更需求和变更的范围; (5) 利用逆向工程和再工程的工具,可以使一部分工作自动化; (6) 在完成预防性维护的过程中可以建立起完整的软件配置。8.6 软件再工程过程8.6 软件再工程过程典型的软件再工程过程模型如图8.3所示,该模型定义了6类活动。 在某些情况下这些活动以线性顺序发生,但也并非总是这样 在图8.3中显示的再工程范型是一个循环模型。这意味着作为该范型的组成部分的每个活动都可能被重复,而且对于任意一个特定的循环来说,过程可以在完成任意一个活动之后终止。null 图8.3 软件再工程过程模型null1. 库存目录分析 每个软件组织都应该保存其拥有的所有应用系统的库存目录。 该目录包含关于每个应用系统的基本信息(例如,应用系统的名字,最初构建它的日期,已做过的实质性修改次数,过去18个月报告的错误,用户数量,安装它的机器数量,它的复杂程度,文档质量,整体可维护性等级,预期寿命,在未来36个月内的预期修改次数,业务重要程度等)。null每一个大的软件开发机构都拥有上百万行老代码,它们都可能是逆向工程或再工程的对象。 但是,某些程序并不频繁使用而且不需要改变 此外,逆向工程和再工程工具尚不成熟,目前仅能对有限种类的应用系统执行逆向工程或再工程 代价又十分高昂,因此,对库中每个程序都做逆向工程或再工程是不现实的。 下述3类程序有可能成为预防性维护的对象: (1) 预定将使用多年的程序; (2) 当前正在成功地使用着的程序; (3) 在最近的将来可能要做重大修改或增强的程序。null应该仔细分析库存目录,按照业务重要程度、寿命、当前可维护性、预期的修改次数等标准,把库中的应用系统排序,从中选出再工程的候选者,然后明智地分配再工程所需要的资源。 2. 文档重构 老程序固有的特点是缺乏文档。具体情况不同,处理这个问题的方法也不同: (1) 建立文档非常耗费时间,不可能为数百个程序都重新建立文档。如果一个程序是相对稳定的,正在走向其有用生命的终点,而且可能不会再经历什么变化,那么,让它保持现状是一个明智的选择。null(2) 为了便于今后的维护,必须更新文档,但是由于资源有限,应采用“使用时建文档”的方法,也就是说,不是一下子把某应用系统的文档全部都重建起来,而是只针对系统中当前正在修改的那些部分建立完整文档。随着时间流逝,将得到一组有用的和相关的文档。 (3) 如果某应用系统是完成业务工作的关键,而且必须重构全部文档,则仍然应该设法把文档工作减少到必需的最小量。null3. 逆向工程 软件的逆向工程是分析程序以便在比源代码更高的抽象层次上创建出程序的某种表示的过程 逆向工程是一个恢复设计结果的过程,逆向工程工具从现存的程序代码中抽取有关数据、体系结构和处理过程的设计信息。 4. 代码重构 代码重构是最常见的再工程活动。某些老程序具有比较完整、合理的体系结构,但是,个体模块的编码方式却是难于理解、测试和维护的。在这种情况下,可以重构可疑模块的代码。null为了完成代码重构活动,首先用重构工具分析源代码,标注出和结构化程序设计概念相违背的部分。然后重构有问题的代码(此项工作可自动进行)。最后,复审和测试生成的重构代码(以保证没有引入异常)并更新代码文档。 通常,重构并不修改整体的程序体系结构,它仅关注个体模块的设计细节以及在模块中定义的局部数据结构。如果重构扩展到模块边界之外并涉及软件体系结构,则重构变成了正向工程。null5. 数据重构 对数据体系结构差的程序很难进行适应性修改和增强,对许多应用系统来说,数据体系结构比源代码本身对程序的长期生存力有更大影响。 与代码重构不同,数据重构发生在相当低的抽象层次上,它是一种全范围的再工程活动。 在大多数情况下,数据重构始于逆向工程活动,分解当前使用的数据体系结构,必要时定义数据模型,标识数据对象和属性,并从软件质量的角度复审现存的数据结构。 当数据结构较差时,应该对数据进行再工程。 由于数据体系结构对程序体系结构及程序中的算法有很大影响,对数据的修改必然会导致体系结构或代码层的改变。null6. 正向工程 正向工程也称为革新或改造,这项活动不仅从现有程序中恢复设计信息,而且使用该信息去改变或重构现有系统,以提高其整体质量。 正向工程过程应用软件工程的原理、概念、技术和方法来重新开发某个现有的应用系统。 在大多数情况下,被再工程的软件不仅重新实现现有系统的功能,而且加入了新功能和提高了整体性能。
本文档为【8.软件工程 维护】,请使用软件OFFICE或WPS软件打开。作品中的文字与图均可以修改和编辑, 图片更改请在作品中右键图片并更换,文字修改请直接点击文字进行修改,也可以新增和删除文档中的内容。
该文档来自用户分享,如有侵权行为请发邮件ishare@vip.sina.com联系网站客服,我们会及时删除。
[版权声明] 本站所有资料为用户分享产生,若发现您的权利被侵害,请联系客服邮件isharekefu@iask.cn,我们尽快处理。
本作品所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用。
网站提供的党政主题相关内容(国旗、国徽、党徽..)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
下载需要: 免费 已有0 人下载
最新资料
资料动态
专题动态
is_248444
暂无简介~
格式:ppt
大小:444KB
软件:PowerPoint
页数:0
分类:互联网
上传时间:2012-01-16
浏览量:51