《软件维护与再工程.pptx》由会员分享,可在线阅读,更多相关《软件维护与再工程.pptx(51页珍藏版)》请在得力文库 - 分享文档赚钱的网站上搜索。
1、软件工程软件工程第第13章章 软件维护与再工程软件维护与再工程1.软件演化是指软件在交付以后,对软件进行的一系列活动的总称。2.软件演化:软件的维护、软件再工程。3.软件维护阶段覆盖了从软件交付使用,到软件被淘汰为止的整个时期。软件的开发时间可能需要一、二年,甚至更短,但它的使用时间可能要经历几年或几十年。4.再工程的主要目的是为遗留系统转化为可演化系统提供一条现实可行的途径,是在软件生命周期终止后开始的一个新的阶段。软件维护与再工程软件维护与再工程 内容内容 u软件维护u再工程技术内容内容 u软件维护u再工程技术软件维护的概念软件维护的概念 u什么是软件维护是指软件系统交付使用以后,为了改正
2、错误或满足新的需要而修改软件的过程 u国标GB/T 11457-95给出如下定义 在软件产品交付使用后对其进行修改,以纠正故障;在软件产品交付使用后对其进行修改,以纠正故障、改进其性能和其它属性,或使产品适应改变了的环境软件维护的概念软件维护分类软件维护的概念软件维护分类u两种错误认识 软件维护是一次新的开发活动 软件维护就是改错 u新开发活动强调要在一定的约束条件下从头开始实施 u软件维护强调必须在现有系统的限定和约束条件下实施;根据起因不同,软件维护可以分为纠错性维护、适应性维护、改善性维护和预防性维护四类 软件维护的概念软件维护分类软件维护的概念软件维护分类1.纠错性维护:为了改正软件系
3、统中的错误,使软件能够满足预期的正常运行状态的要求而进行的维护2.适应性维护:为了使软件适应内部或外部环境变化,而去修改软件的过程3.改善性维护:满足使用过程中用户提出增加新功能或修改已有功能的建议维护4.预防性维护:为了提高软件的可维护性、可靠性等,为以后进一步改进软件打下良好基础而修改软件的活动软件维护的概念维护问题软件维护的概念维护问题u维护时:u维护人员从分析需求规格说明开始,u明白软件功能和性能上的改变,u对设计说明文档进行修改和复查,u再根据设计修改进行程序变动,u并用测试文档中的测试用例进行回归测试,u最后将修改后的软件再次交付使用。软件维护的概念维护问题软件维护的概念维护问题u
4、和软件维护有关的局部问题:1.理解别人的代码通常是非常困难的,而且难度随着软件配置成分的缺失而迅速增加2.需要维护的软件往往没有文档、或文档资料严重缺乏、或软件的变化未在相应的文档中反映出来3.当软件要求维护时,不能指望由原来的开发人员来完成或提供软件的解释。由于维护持续时间很长,因此当需要解释软件时候,往往开发人员已经不在附近了4.绝大多数软件在设计时没有考虑到将来的修改问题5.软件维护这项工作毫无吸引力。一方面是因为软件维护,看不到什么“成果,但工作量很大,更重要的是维护工作难度大,软件维护人员经常遭受挫折。软件维护的概念维护成本软件维护的概念维护成本u软件维护除费用外的无形代价包括1.维
5、护活动占用了其他软件开发可用的资源,使资源的利用率降低 2.一些修复或修改请求得不到及时安排,使得客户满意率下降 3.维护的结果把一些新的潜在的错误引入软件,降低了软件质量 4.将软件人员抽调到维护工作中,使得其它软件开发过程受到干扰 软件维护的概念维护成本软件维护的概念维护成本u维护的工作可划分成 1.生产性活动 如,分析评价、修改设计、编写程序代码等 2.非生产性活动 如,程序代码功能理解、数据结构解释、接口特点和性能界限分析等u维护工作量的模型 M:维护的总工作量;P:生产性工作量;K:经验常数;c:复杂程度;d:维护人员对软件的熟悉程度 软件维护的概念维护成本软件维护的概念维护成本u影
6、响维护工作量的因素主要有以下六种1.系系统的的规模模:系统规模越大,其功能就越复杂,软件维护的工作量也随之增大2.程序程序设计语言言:使用强功能的程序设计语言可以控制程序的规模。语言的功能越强,生成程序的模块化和结构化程度越高,所需的指令数就越少,程序的可读性也越好3.系系统年年龄:老系统比新系统需要更多的维护工作量。4.数据数据库技技术的的应用用:使用数据库,可以简单而有效地管理和存储用户程序中的数据,还可以减少生成用户报表应用软件的维护工作量 5.先先进的的软件开件开发技技术:在软件开发过程中,如果采用先进的分析设计技术和程序设计技术,如面向对象技术、复用技术等,可减少大量的维护工作量6.
7、其它一些因素其它一些因素:如应用的类型、数学模型、任务的难度、IF嵌套深度、索引或下标数等,对维护工作量也有影响 软件维护的过程维护组织软件维护的过程维护组织u维护组织结构图 系统监督员一般都是对程系统监督员一般都是对程序序某一局部某一局部特别熟悉特别熟悉的技术人员。的技术人员。在维护人员对程序进行修在维护人员对程序进行修改的过程中,由配置管理改的过程中,由配置管理员严格把关,控制修改的员严格把关,控制修改的范围,对软件配置进行审范围,对软件配置进行审计计。维护管理员、系统监督员、修维护管理员、系统监督员、修改控制决策机构等,均代表维改控制决策机构等,均代表维护工作的某个职责范围护工作的某个职
8、责范围。软件维护的过程维护组织软件维护的过程维护组织u维护团队根据时间的不同,可以分为短期团队和长期团队 u短期短期团队一般是当需要执行相关具体任务时,临时组织起来解决手头的问题 u长期期团队则更正式,能够专业化创立沟通渠道,可以管理软件系统整个生存期的成功演化 u无论是短期团队还是长期团队,都要把有经验的员工和新员工混合起来。软件维护的过程维护过程软件维护的过程维护过程u非纠错性维护,则首先判断维护类型,对适应性维护,按照评估后得到的优先级放入队列 u改善性维护,则还要考虑是否采取行动,如果接受申请,则同样按照评估后得到的优先级放入队列,如果拒绝申请,则通知请求者,并说明原因u工作安排队列中
9、的任务,由修改负责人依次从队列中取出任务,按照软件工程方法学规划、组织、实施工程。软件维护的过程维护过程软件维护的过程维护过程维护请求维护请求类型类型类型类型严重性严重性评估后按优先评估后按优先级在队列排队级在队列排队救火行动,当救火行动,当排在队列之首排在队列之首评估后分类评估后分类评估后按优先评估后按优先级在队列排队级在队列排队采取的行动采取的行动通知请求者通知请求者并说明原因并说明原因按优先级在按优先级在队列中排队队列中排队从维护请求队列之首取出一任务从维护请求队列之首取出一任务按按SESE方法学规划、组织、实施工程方法学规划、组织、实施工程队列中还有维护请求吗?队列中还有维护请求吗?资
10、源用于开发新的软件。资源用于开发新的软件。y yn n纠错性维护纠错性维护其他其他改善性维护改善性维护适应性维护适应性维护拒绝拒绝接受接受并不严重并不严重非常严重非常严重维护过程图维护过程图软件维护的过程维护过程软件维护的过程维护过程u维护工作最后一步是复审 1.依照当前状态,在设计、编码和测试的哪些方面还能用其他方法进行?2.哪些维护资源可用但未用?3.这次维护活动中主要或次要的障碍有哪些?4.在维护请求中有预防性维护吗?软件维护的过程维护记录软件维护的过程维护记录u维护人员对程序进行修改前要着重做好两个记录维护申请报告软件修改报告 u维护请求表求表报告即告即软件件问题报告告u该报告表由要求
11、维护活动的用户填写。u对改正性维护,用户需要将错误出现的现场信息详细描述出来,包括输入数据、错误清单以及其它有关材料。u对适应性维护或改善性维护,应该给出简短的需求规格说明书。u维护申请被批准后,维护申请报告就成为外部文档,作为本次维护的依据 软件维护的过程维护评价软件维护的过程维护评价u如果已经开始保存维护记录,可以对维护工作做一些定量度量,至少可以从如下7方面进行评价:1.每次程序运行平均失败的次数;2.用于每一类维护活动的总人时数;3.平均每个程序、每种语言、每种维护类型所必需的程序变动数;4.维护过程中增加或删除源语句平均花费的人时数;5.维护每种语言平均花费的人时数;6.一张维护请求
12、表的平均周转时间;7.不同维护类型所占的比例;软件可维护性软件可维护性 u可维护性maintainability指理解、改正、调整和改进软件的难易程度。对软件可维护性影响的主要因素有:可理解性understandability、可测试性testability、可修改性、modifiability可移植性portability 软件可维护性主要影响因素软件可维护性主要影响因素u可理解性:指理解软件的结构、接口、功能和内部过程的难易程度。u提高软件可理解性的措施有:u采用模块化的程序结构;u书写详细正确的文档;u采用结构化程序设计;u书写源程序的内部文档;u使用良好的编程语言;u具有良好的程序设计
13、风格等 软件可维护性主要影响因素软件可维护性主要影响因素u可测试性:指测试和诊断软件主要指程序中错误的难易程度。提高软件可测试性的措施有:C采用良好的程序结构;C书写详细正确的文档;C使用测试工具和调试工具;C保存以前的测试过程和测试用例等 软件可维护性主要影响因素软件可维护性主要影响因素u可修改性:指修改软件主要指程序的难易程度。在修改软件时经常会发生这样的情况:C修改了程序中某个错误的同时又产生新的错误由程序的修改引起的;C或者在程序中增加了某个功能后,导致原先的某些功能不能正常执行。软件可维护性主要影响因素软件可维护性主要影响因素u可移植性:指程序转移到一个新的计算环境的难易程度。影响软
14、件可移植性的因素有:C信息隐蔽原则;C模块独立;C模块化;C高内聚低耦合;C良好的程序结构;C不用标准文本以外的语句等一个可移植的程序应具有结构良好、灵活、不依赖于某一具体计算机或操作系统的性能 软件可维护性主要影响因素软件可维护性主要影响因素u通常对于软件可移植性的度量考虑如下因素 1.是否是用高级的独立于机器的语言来编写程序?2.是否采用广泛使用的标准化的程序设计语言来编写程序?是否仅使用了这种语言的标准版本和特性?3.程序中是否使用了标准的普遍使用的库功能和子程序?4.程序中是否极少使用或根本不使用操作系统的功能?软件可维护性主要影响因素软件可维护性主要影响因素5.程序在执行之前是否初始
15、化内存?6.程序在执行之前是否测定当前的输入输出设备?7.程序是否把与机器相关的语句别离了出来,集中放在了一些单独的程序模块中,并有说明文件?8.程序是否结构化?并允许在小一些的计算机上分段覆盖运行?9.程序中是否防止了依赖于字母数字或特殊字符的内部位表示?软件可维护性软件可维护性评审软件可维护性软件可维护性评审u在进行设计评审时,要从易于维护和提高设计总体质量的角度全面评审:u数据设计u总体结构设计u过程设计u界面设计u在进行代码评审时,要强调编程风格和内部文档u在进行测试时应指出软件正式交付前应进行的预防性维护u在维护活动完成后也要进行评审。软件可维护性提高可维护性的方法软件可维护性提高可
16、维护性的方法u提高可维护性通常采用的方法有1.确定质量管理目标和优先级2.标准化程序设计风格3.选择可维护性高的程序设计语言4.改进程序文档5.保证软件质量审查方法 软件可维护性提高可维护性的方法软件可维护性提高可维护性的方法u确定质量管理目标和优先级 一个可维护的程序应该是C可理解的C可修改的C可测试的C有些维护属性之间是相互促进的,另外一些属性之间则是相互抵触的。在程序的开发阶段就应保证软件具有可理解性、可修改性和可测试性。在软件开发的每一个阶段都应尽力考虑软件的可维护性。软件可维护性提高可维护性的方法软件可维护性提高可维护性的方法u使用提高软件质量的技术与工具在进行软件设计时,采用:C模
17、块化程序设计C结构化程序设计在软件开发过程中,采用:C结构化小组,建立主程序小组C实现严格的组织化管理,职能分工C标准标准在对程序的质量进行检测时,采用:C分工合作的方法这些方法会有效地提高软件质量和检测效率,进而提高软件的可维护性。软件可维护性提高可维护性的软件可维护性提高可维护性的方法方法u选择可维护性高的程序设计语言 选择较好的程序设计语言对软件维护有很大的影响。C低级语言如:机器代码或汇编语言程序是一般人很难掌握和理解的,因而很难维护。C高级语言比低级语言容易理解,具有更好的可维护性。C在高级语言中,一些语言可能比另外一些语言更容易理解。例如,cobol语言比fortran语言更容易理
18、解,因为cobol的变量接近英语;软件可维护性提高可维护性的软件可维护性提高可维护性的方法方法u改进程序文档 程序文档对提高程序的可理解性有着重要的作用。C即使是一个相对简单的程序,要想有效地、迅速对它进行维护,也需要编制文档,对它的目的和任务进行解释。C对于程序的维护人员来说,要想对程序编制人员的意图进行重新修改,并对今后可能出现的变化估计,缺少文档的帮助也将很难实现。C另一方面,对于程序文档一定要能及时反映程序的变化,否则将对后续维护人员产生误导。软件可维护性提高可维护性的软件可维护性提高可维护性的方法方法u进行质量保证审查 审查可以用来检测在开发和维护阶段内发生的质量变化。一旦发现问题,
19、就可以采取措施来纠正,以控制不断增长的软件维护成本,延长软件系统的有效生命期。为了保证软件的可维护性,有四种类型的软件审查:C在检查点进行复审C验收检查C周期性地维护审查C对软件包进行检查。内容内容 u软件维护u再工程技术再工程的概念再工程的概念 u逆向工程reverse engineering:指在软件生存周期中,将软件的某种形式描述转换成更抽象形式的活动u重构restructuring:指在同一抽象级别上转换系统的描述形式。如把C+程序转换成Java程序u设计恢复design recovery:指借助工具从已有程序中抽象出有关数据结构设计、总体结构设计和过程设计的信息。再工程的概念再工程的
20、概念u再工程reengineering:指在逆向工程所获信息的基础上修改或重构已有的系统,产生系统的一个新版本 u再工程的主要目的:为遗留系统转化为可演化系统提供一条现实可行的途径 u再工程是一个工程过程,它将逆向工程、重构和正向工程组合起来,将现存系统重新构造为新的形式。当实施软件的再工程时,软件理解是再工程的基础和前提。再工程的概念再工程的概念u为什么要进行再工程 维护一行源代码的代价可能是最初开发该行源代码代价的14-20倍;同时重新设计软件体系结构时使用了现代设计概念,它对将来的维护会有很大的帮助;现有的程序版本可以作为软件原型使用,开发生产率可以大大高于平均水平;用户具有较多使用该软
21、件的经验,因此,能够很容易地搞清新的变更需求和变更的范围;另外,利用逆向工程和再工程的工具,可以使一局部工作自动化;在完成预防性维护的过程中还可以建立起完整的软件配置。再工程的概念再工程的概念u通常再工程包含:业务过程再工程、软件再工程 业务过程再工程程再工程BPRBusiness Process Re-engineering,也称业务过程重组1.定义业务目标2.标示并评估现有的业务过程3.修订业务过程以更好满足业务目标软件再工程件再工程包含:1.库存目录分析2.文档重构3.逆向工程4.程序和数据重构5.正向工程业务过程再工程业务过程再工程 u业务过程是一组“逻辑相关的任务,它们被执行以到达符
22、合预定义的业务结果。u每个系统都是由不同的子系统构成,而子系统还可以再细分为更细的子系统,从而整个业务呈现一种层次结构 业务业务 业务系统业务系统 业务过程业务过程 业务子过程业务子过程业务层次业务层次 业务过程再工程业务过程再工程u业务过程再工程是迭代的,不断演化的。整个业务过程再工程模型可用以下图表示业务定义过程标识过程评估过程规约和设计原型实现求精和实例化软件再工程过程软件再工程过程 u在业务过程被分析清楚后,可以对软件实施再工程,整个软件再工程过程模型如以下图 软件再工程过程软件再工程过程u库存目录分析l包含关于每个应用系统的基本信息1.应用系统的名字2.最初构建它的日期3.已做过的实
23、质性修改次数4.过去18个月报告的错误5.用户数量6.安装它的机器数量7.它的复杂程度8.文档质量9.整体可维护性等级10.预期寿命11.在未来36个月内的预期修改次数12.业务重要程度等软件再工程过程软件再工程过程u文档重构建立文档非常消耗时间,不可能为数百个程序都重新建立文档。如果一个程序是相对稳定的,而且可能不会再经历什么变化,那么,让它保持现状。为了便于今后的维护,必须更新文档,但只针对系统中当前正在修改的那些局部建立完整文档。如果某应用系统是完成业务工作的关键,而且必须重构全部文档,则仍然应该设法把文档工作减少到必需的最小量。软件再工程过程软件再工程过程u逆向工程软件的逆向工程是分析
24、程序,以便在比源代码更高的抽象层次上,创立出程序的某种表示的过程;逆向工程工具从现存的程序代码中抽取有关数据、体系结构和处理过程的设计信息。软件再工程过程软件再工程过程u代码重构某些老程序具有比较完整、合理的体系结构,但是,个体模块的编码方式却是难于理解、测试和维护的。在这种情况下,可以重构可疑模块的代码。为了完成代码重构活动:C首先首先用重构工具分析源代码,标注出和结构化程序设计概念相违背的局部。C然后然后重构有问题的代码此项工作可自动进行。C最后最后复审和测试生成的重构代码以保证没有引入异常并更新代码文档。软件再工程过程软件再工程过程u数据重构数据重构发生在相当低的抽象层次上,它是一种全范
25、围的再工程活动。在大多数情况下,数据重构始于逆向工程活动,分解当前使用的数据体系结构,必要时定义数据模型,标识数据对象和属性,并从软件质量的角度复审现存的数据结构。软件再工程过程软件再工程过程u正向工程正向工程过程应用软件工程的原理、概念、技术和方法来重新开发某个现有的应用系统。在大多数情况下,被再工程的软件不仅重新实现现有系统的功能,而且参加了新功能和提高了整体性能。逆向工程逆向工程u逆向工程导出的信息可分为四个抽象层次1.实现级:包括程序的抽象语法树、符号表等信息;2.结构级:包括反映程序分量之间相互依赖关系的信息,如调用图、结构图等;3.功能级:包括反映程序段功能及程序段之间关系的信息;
26、4.领域级:包括反映程序分量或程序诸实体与应用领域概念之间对应关系的信息。对于一项具体的维护任务,一般不必导出所有抽象级别上的信息。如代码重构任务,只需获得实现级信息即可。逆向工程逆向工程u对数据的逆向工程:由于程序中存在许多不同种类的数据,例如内部的数据结构,以及底层的数据库和外部的文件。u对内部的数据内部的数据结构的逆向工程可以通构的逆向工程可以通过检查程序代程序代码以及以及变量来完成;量来完成;u对数据数据库结构的重构,可通构的重构,可通过建立一个初始的建立一个初始的对象模型,确定侯象模型,确定侯选键,精化,精化实验性的性的类,定,定义一般化,以及一般化,以及发现关关联来完成。来完成。u
27、对理解的逆向工程:为了去理解过程的抽象,代码的分析必须在不同的层次进行:u系系统u程序程序u部件部件u模式模式u语句句u对于大型系统,逆向工程通常用半自动化的方法来完成。逆向工程逆向工程u逆向工程中用于恢复信息的方法主要有四类用户指导下的搜索与变换:这类方法用于导出实现级和结构级信息。这类方法一般可产生模块的略图outline、流程图和交叉访问表。变换方法:这类方法可用于恢复实现级、结构级和功能级的信息。这类方法可用工具实现,如静态分析,调用图、控制流图生成等。基于领域知识的方法:这类方法用于恢复功能级和领域级信息。领域知识用规则库表示,用已确定或假定的领域概念与代码之间的对应关系,推导进一步的假设,最后导出程序的功能。这类方法的不确定性很大,目前尚无成熟的工具。铅板恢复:这类方法仅适用于推导实现级和结构级信息。这类方法用于识别程序设计“铅板或公共结构,铅板既可是一个简单算法如二变量互换,也可是相对复杂的成分如冒泡排序。内容小结内容小结u软件维护u再工程技术
限制150内