《[精选]13章软件维护与再工程.pptx》由会员分享,可在线阅读,更多相关《[精选]13章软件维护与再工程.pptx(59页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、软件工程软件工程软件工程软件工程第13章 软件维护与再工程2内容内容 软件件维护再工程技再工程技术3软件件维护的概念的概念 什么是什么是软件件维护是指软件系统交付使用以后,为了改正错误或满足新的需要而修改软件的过程 国国标GB/T 11457-95给出如下定出如下定义 在一软件产品交付使用后对其进行修改,以纠正故障、改进其性能和其它属性,或使产品适应改变了的环境。两种两种错误认识 软件维护是一次新的开发活动 软件维护就是改错 新开新开发活活动强调要在一定的要在一定的约束条件下从束条件下从头开始开始实施施 软件件维护强调必必须在在现有系有系统的限定和的限定和约束条件下束条件下实;4软件件维护的概
2、念的概念软件件维护分分类根据起因不同,根据起因不同,软件件维护可以分可以分为四四类纠错性维护适应性维护改善性维护预防性维护5软件件维护的概念的概念软件件维护分分类纠错性性维护:为了改正了改正软件系件系统中的中的错误,使,使软件能件能够满足足预期的正常运行状期的正常运行状态的要求而的要求而进行的行的维护适适应性性维护:为了使了使软件适件适应内部或外部内部或外部环境境变化,而化,而去修改去修改软件的件的过程程改善性改善性维护:满足使用足使用过程中用程中用户提出增加新功能或修提出增加新功能或修改已有功能的建改已有功能的建议维护预防性防性维护:为了提高了提高软件的可件的可维护性、可靠性等,性、可靠性等
3、,为以后以后进一步改一步改进软件打下良好基件打下良好基础而修改而修改软件的活件的活动在实践中,软件维护各种活动常常交织在一起,在实践中,软件维护各种活动常常交织在一起,尽管这些维护在性质上有些重叠,但是还是有充尽管这些维护在性质上有些重叠,但是还是有充分的理由区分这些维护活动分的理由区分这些维护活动只有正确区分维护活动的类型才能够更有效地确只有正确区分维护活动的类型才能够更有效地确定维护需求的优先级定维护需求的优先级 6四类软件维护的比例四类软件维护的比例纠错性维纠错性维纠错性维纠错性维纠错性维纠错性维护护护护护护25%25%25%25%25%25%适应性适应性维护维护21%完善性完善性完善性
4、完善性维护维护维护维护50%50%预防性预防性预防性预防性维护维护维护维护4%4%7软件件维护的概念的概念维护问题结构化构化维护:采用:采用软件工程的方法件工程的方法进行行软件开件开发,保,保证每个每个阶段都有完整且段都有完整且详细的文档的文档非非结构化构化维护:如果不采用:如果不采用软件工程方法开件工程方法开发软件,件,软件只有程序而欠缺文档,件只有程序而欠缺文档,则维护工作工作将将变得十分困得十分困难 维护时,开,开发人人员从分析需求从分析需求规格格说明开始,明开始,明白明白软件功能和性能上的改件功能和性能上的改变,对设计说明文明文档档进行修改和复行修改和复查,再根据,再根据设计修改修改进
5、行程序行程序变动,并用,并用测试文档中的文档中的测试用例用例进行回行回归测试,最后将修改后的,最后将修改后的软件再次交付使用。件再次交付使用。8软件件维护的概念的概念维护问题和和软件件维护有关的局部有关的局部问题:理解别人的代码通常是非常困难的,而且难度随着软件配置理解别人的代码通常是非常困难的,而且难度随着软件配置成分的缺失而迅速增加成分的缺失而迅速增加需要维护的软件往往没有文档、或文档资料严重缺乏、或软需要维护的软件往往没有文档、或文档资料严重缺乏、或软件的变化未在相应的文档中反映出来件的变化未在相应的文档中反映出来当软件要求维护时,不能指望由原来的开发人员来完成或提当软件要求维护时,不能
6、指望由原来的开发人员来完成或提供软件的解释。由于维护持续时间很长,因此当需要解释软供软件的解释。由于维护持续时间很长,因此当需要解释软件时候,往往开发人员已经不在附近了件时候,往往开发人员已经不在附近了绝大多数软件在设计时没有考虑到将来的修改问题绝大多数软件在设计时没有考虑到将来的修改问题软件维护这项工作毫无吸引力。一方面是因为软件维护,看软件维护这项工作毫无吸引力。一方面是因为软件维护,看不到什么不到什么“成果成果,但工作量很大,更重要的是维护工作难,但工作量很大,更重要的是维护工作难度大,软件维护人员经常遭受挫折。度大,软件维护人员经常遭受挫折。9软件件维护的概念的概念维护成本成本软件件维
7、护除除费用外的无形代价包括用外的无形代价包括维护活动占用了其他软件开发可用的资源,使资维护活动占用了其他软件开发可用的资源,使资源的利用率降低源的利用率降低 一些修复或修改请求得不到及时安排,使得客户一些修复或修改请求得不到及时安排,使得客户满意率下降满意率下降 维护的结果把一些新的潜在的错误引入软件,降维护的结果把一些新的潜在的错误引入软件,降低了软件质量低了软件质量 将软件人员抽调到维护工作中,使得其它软件开将软件人员抽调到维护工作中,使得其它软件开发过程受到干扰发过程受到干扰 10软件件维护的概念的概念维护成本成本维护的工作可划分成:的工作可划分成:生产性活动 如,分析评价、修改设计、编
8、写程序代码等 非生产性活动 如,程序代码功能理解、数据结构解释、接口特点和性能界限分析等维护工作量的模型工作量的模型 M:维护的总工作量;P:生产性工作量;K:经验常数;c:复杂程度;d:维护人员对软件的熟悉程度 11软件件维护的概念的概念维护成本成本影响影响维护工作量的因素主要有以下六种工作量的因素主要有以下六种系统的规模:系统规模越大,其功能就越复杂,软件维护的工作量也随之增大程序设计语言:使用强功能的程序设计语言可以控制程序的规模。语言的功能越强,生成程序的模块化和结构化程度越高,所需的指令数就越少,程序的可读性也越好系统年龄:老系统比新系统需要更多的维护工作量。12软件件维护的概念的概
9、念维护成本成本数据库技术的应用:使用数据库,可以简单而有效地管理和存储用户程序中的数据,还可以减少生成用户报表应用软件的维护工作量 先进的软件开发技术:在软件开发过程中,如果采用先进的分析设计技术和程序设计技术,如面向对象技术、复用技术等,可减少大量的维护工作量其它一些因素:如应用的类型、数学模型、任务的难度、IF嵌套深度、索引或下标数等,对维护工作量也有影响 13软件件维护的的过程程维护活活动包括:包括:建立维护组织确定维护过程保管维护记录进行维护评价14软件件维护的的过程程维护组织维护组织结构构图 16软件件维护的的过程程维护组织维护团队根据根据时间的不同的不同,可以分可以分为短期短期团队
10、和和长期期团队 短期短期团队一般是当需要一般是当需要执行相关具体任行相关具体任务时,临时组织起来解决手起来解决手头的的问题 长期期团队则更正式,能更正式,能够专业化化创立沟通渠道,立沟通渠道,可以管理可以管理软件系件系统整个生存期的成功演化整个生存期的成功演化 无无论是短期是短期团队还是是长期期团队,都要把有,都要把有经验的的员工和新工和新员工混合起来。工混合起来。17软件件维护的的过程程维护过程程对于非于非纠错性性维护,则首先判断首先判断维护类型,型,对适适应性性维护,按照,按照评估后得到的估后得到的优先先级放入放入队列列 对于改善性于改善性维护,则还要考要考虑是否采取行是否采取行动,如果接
11、受申如果接受申请,则同同样按照按照评估后得到的估后得到的优先先级放入放入队列,如果拒列,如果拒绝申申请,则通知通知请求者,求者,并并说明原因明原因对于工作安排于工作安排队列中的任列中的任务,由修改,由修改负责人依人依次从次从队列中取出任列中取出任务,按照,按照软件工程方法学件工程方法学规划、划、组织、实施工程。施工程。18软件件维护的的过程程维护过程程维护请求维护请求类型类型类型类型严重严重性性评估后按优先评估后按优先级在队列排队级在队列排队救火行动,当救火行动,当排在队列之首排在队列之首评估后分类评估后分类评估后按优先评估后按优先级在队列排队级在队列排队采采取取的的行行动动通知请求者通知请求
12、者并说明原因并说明原因按优先级在按优先级在队列中排队队列中排队从维护请求队列之首取出一任务从维护请求队列之首取出一任务按按SESE方法学规划、组织、实施工程方法学规划、组织、实施工程队列中还有维护请队列中还有维护请求吗?求吗?资源用于开发新的软件。资源用于开发新的软件。y yn n纠错性维护纠错性维护其他其他改善性维改善性维护护适应性维护适应性维护拒绝拒绝接受接受并不严重并不严重非常严重非常严重维护过程图维护过程图19软件件维护的的过程程维护过程程每种每种维护请求都要求都要进行同行同样的一系列技的一系列技术工作:工作:修改软件需求说明、修改软件需求说明、修改软件设计、修改软件设计、设计评审、设
13、计评审、必要时重新编码、必要时重新编码、单元测试、单元测试、集成测试集成测试 包括回归测试包括回归测试、确认测试等确认测试等 维护工作最后一步是复工作最后一步是复审,保保证满足足维护请求求的要求的要求 20软件件维护的的过程程维护记录维护人人员对程序程序进行修改前要着重做好两个行修改前要着重做好两个记录维护申请报告维护申请报告软件修改报告软件修改报告 维护请求表求表报告即告即软件件问题报告,告,该报告表由告表由要求一要求一项维护活活动的用的用户填写。填写。对改正性改正性维护,用,用户需需要将要将错误出出现的的现场信息信息详细描述出来,包括描述出来,包括输入数据、入数据、错误清清单以及其它有关材
14、料。以及其它有关材料。对适适应性性维护或改善性或改善性维护,应该给出一个出一个简短的需求短的需求规格格说明明书。维护申申请被被批准后,批准后,维护申申请报告就成告就成为外部文档,作外部文档,作为本次本次维护的依据的依据软件修改件修改报告指明:告指明:为满足足维护申申请报告提出的需求所告提出的需求所需的工作量、本次需的工作量、本次维护活活动的的类别、本次、本次维护请求的求的优先先级、本次修改的背景数据。在、本次修改的背景数据。在拟定定进一步一步维护方案前,方案前,软件修改件修改报告要提交告要提交给修改决策机构,供修改决策机构,供进一步一步规划划维护活活动使用使用 21软件件维护的的过程程维护评价
15、价如果已如果已经开始保存开始保存维护记录,可以,可以对维护工作工作做一些定量度量,至少可以从如下做一些定量度量,至少可以从如下7方面方面进行行评价:价:每次程序运行平均失败的次数;用于每一类维护活动的总人时数;平均每个程序、每种语言、每种维护类型所必需的程序变动数;维护过程中增加或删除源语句平均花费的人时数;维护每种语言平均花费的人时数;一张维护请求表的平均周转时间;不同维护类型所占的比例;22软件可件可维护性性 可可维护性性maintainability指理解、改正、调整和改进软件的难易程度。对软件可维护性影响的主要因素有:可理解性可理解性understandability、可测试性可测试性
16、testability、可修改性、可修改性、modifiability和可移植性和可移植性portability 23软件可件可维护性主要影响因素性主要影响因素可理解性:指理解可理解性:指理解软件的件的结构、接口、功能和构、接口、功能和内部内部过程的程的难易程度。易程度。提高提高软件可理解性的措施有:件可理解性的措施有:采用模块化的程序结构;采用模块化的程序结构;书写详细正确的文档;书写详细正确的文档;采用结构化程序设计;采用结构化程序设计;书写源程序的内部文档;书写源程序的内部文档;使用良好的编程语言;使用良好的编程语言;具有良好的程序设计风格等具有良好的程序设计风格等 24软件可件可维护性
17、主要影响因素性主要影响因素可可测试性:指性:指测试和和诊断断软件主要指程件主要指程序中序中错误的的难易程度。易程度。提高提高软件可件可测试性的措施有:性的措施有:采用良好的程序结构;采用良好的程序结构;书写详细正确的文档;书写详细正确的文档;使用测试工具和调试工具;使用测试工具和调试工具;保存以前的测试过程和测试用例等保存以前的测试过程和测试用例等 25软件可件可维护性主要影响因素性主要影响因素可修改性:指修改软件主要指程序的难易程度。可修改性:指修改软件主要指程序的难易程度。在修改软件时经常会发生这样的情况:修改了程序中某个错误在修改软件时经常会发生这样的情况:修改了程序中某个错误的同时又产
18、生新的错误由程序的修改引起的;或者在程序的同时又产生新的错误由程序的修改引起的;或者在程序中增加了某个功能后,导致原先的某些功能不能正常执行。中增加了某个功能后,导致原先的某些功能不能正常执行。修改影响涉及范围越大修改影响涉及范围越大,则程序的可修改性就越差。则程序的可修改性就越差。影响可修改性因素:软件设计中的设计准则和启发式规影响可修改性因素:软件设计中的设计准则和启发式规则。则。一个可修改的软件应当是可理解的、通用的、灵活的、一个可修改的软件应当是可理解的、通用的、灵活的、简单的。其中:简单的。其中:通用性:指软件适用于各种功能变化而无需修改。通用性:指软件适用于各种功能变化而无需修改。
19、灵活性:是指能够容易的对软件进行修改。灵活性:是指能够容易的对软件进行修改。26软件可件可维护性主要影响因素性主要影响因素可移植性:指程序可移植性:指程序转移到一个新的移到一个新的计算算环境的境的难易程度。易程度。影响影响软件可移植性的因素有:信息件可移植性的因素有:信息隐蔽原蔽原则;模模块独立;模独立;模块化;高内聚低耦合;良好的程化;高内聚低耦合;良好的程序序结构;不用构;不用标准文本以外的准文本以外的语句等句等一个可移植的程序一个可移植的程序应具有具有结构良好、灵活、不构良好、灵活、不依依赖于某一具体于某一具体计算机或操作系算机或操作系统的性能的性能 27软件可件可维护性主要影响因素性主
20、要影响因素通常通常对于于软件可移植性的度量考件可移植性的度量考虑如下因素如下因素 是否是用高级的独立于机器的语言来编写程序是否是用高级的独立于机器的语言来编写程序?是否采用广泛使用的标准化的程序设计语言来编写程序是否采用广泛使用的标准化的程序设计语言来编写程序?是否是否仅使用了这种语言的标准版本和特性仅使用了这种语言的标准版本和特性?程序中是否使用了标准的普遍使用的库功能和子程序程序中是否使用了标准的普遍使用的库功能和子程序?程序中是否极少使用或根本不使用操作系统的功能程序中是否极少使用或根本不使用操作系统的功能?程序在执行之前是否初始化内存程序在执行之前是否初始化内存?程序在执行之前是否测定
21、当前的输入输出设备程序在执行之前是否测定当前的输入输出设备?程序是否把与机器相关的语句别离了出来,集中放在了一些单程序是否把与机器相关的语句别离了出来,集中放在了一些单独的程序模块中,并有说明文件独的程序模块中,并有说明文件?程序是否结构化程序是否结构化?并允许在小一些的计算机上分段并允许在小一些的计算机上分段覆盖覆盖运运行行?程序中是否防止了依赖于字母数字或特殊字符的内部位表示程序中是否防止了依赖于字母数字或特殊字符的内部位表示?28软件可件可维护性性软件可件可维护性性评审在在进行需求分析行需求分析评审时,要考,要考虑可修改性、可移植性,可修改性、可移植性,及影响及影响维护的系的系统接口。接
22、口。在在进行行设计评审时,要从易于,要从易于维护和提高和提高设计总体体质量量的角度全面的角度全面评审数据数据设计、总体体结构构设计、过程程设计和和界面界面设计。在在进行代行代码评审时,要,要强调编程程风格和内部文档。格和内部文档。在在进行行测试时应指出指出软件正式交付前件正式交付前应进行的行的预防性防性维护。在。在维护活活动完成后也要完成后也要进行行评审。29软件可件可维护性提高可性提高可维护性的方法性的方法通常采用的方法有通常采用的方法有确定质量管理目标和优先级使用提高软件质量的技术与工具选择可维护性高的程序设计语言改进程序文档进行质量保证审查30软件可件可维护性提高可性提高可维护性的方法性
23、的方法确定确定质量管理目量管理目标和和优先先级 一个可维护的程序应该是可理解的,可修改的和可测试的。但是要实现所有这些目标,需要付出很大的代价。因为有些维护属性之间是相互促进的,例如,可理解性和可测试性,可理解性和可修改性,另外一些属性之间则是相互抵触的。在程序的开发阶段就应保证软件具有可理解性。可修改性和可测试性。在软件开发的每一个阶段都应尽力考虑软件的可维护性。31软件可件可维护性提高可性提高可维护性的方法性的方法使用提高使用提高软件件质量的技量的技术与工具与工具在进行软件设计时,采用如本书前面所述的模块化程序设计、结构化程序设计等程序设计方法,在软件开发过程中,采用结构化小组,建立主程序
24、小组,实现严格的组织化管理,职能分工,标准标准,在对程序的质量进行检测时,也可以采用分工合作的方法,这些方法会有效地提高软件质量和检测效率,进而提高软件的可维护性。32软件可件可维护性提高可性提高可维护性的方法性的方法选择可可维护性高的程序性高的程序设计语言言 选择较好的程序设计语言对软件维护有很大的影响。低级语言如:机器代码或汇编语言程序是一般人很难掌握和理解的,因而很难维护。高级语言比低级语言容易理解,具有更好的可维护性。在高级语言中,一些语言可能比另外一些语言更容易理解。例如,cobol语言比fortran语言更容易理解,因为cobol的变量接近英语;pl/1比cobol更容易理解,因为
25、pl/1有更丰富、更强的语言集等 33软件可件可维护性提高可性提高可维护性的方法性的方法改改进程序文档程序文档 程序文档对提高程序的可理解性有着重要的作用。即使是一个相对简单的程序,要想有效地,迅速对它进行维护,也需要编制文档对它的目的和任务进行解释。而对于程序的维护人员来说,要想对程序编制人员的意图进行重新修改,并对今后可能出现的变化估计,缺少文档的帮助也将很难实现。另一方面,对于程序文档一定要能及时反映程序的变化,否则将对后续维护人员产生误导。34软件可件可维护性提高可性提高可维护性的方法性的方法进行行质量保量保证审查 除了保证软件得到适当的质量外,审查还可以用来检测在开发和维护阶段内发生
26、的质量变化。一旦检测出问题来,就可以采取措施来纠正,以控制不断增长的软件维护成本,延长软件系统的有效生命期。为了保证软件的可维护性,有四种类型的软件审查:在检查点进行复审、验收检查、周期性地维护审查、对软件包进行检查。35内容内容 软件件维护再工程技再工程技术36再工程的概念再工程的概念 逆向工程逆向工程reverse engineering:指在:指在软件件生存周期中,将生存周期中,将软件的某种形式描述件的某种形式描述转换成更成更抽象形式的活抽象形式的活动重构重构restructuring:指在同一抽象:指在同一抽象级别上上转换系系统的描述形式。如把的描述形式。如把C+程序程序转换成成Jav
27、a程序程序设计恢复恢复design recovery:指借助工具从:指借助工具从已有程序中抽象出有关数据已有程序中抽象出有关数据结构构设计、总体体结构构设计和和过程程设计的信息。的信息。37再工程的概念再工程的概念再工程再工程reengineering:指在逆向工程所:指在逆向工程所获信息的基信息的基础上修改或重构已有的系上修改或重构已有的系统,产生系生系统的一个新版本的一个新版本 再工程的主要目的:再工程的主要目的:为遗留系留系统转化化为可演化可演化系系统提供一条提供一条现实可行的途径可行的途径 再工程是一个工程再工程是一个工程过程,它将逆向工程、重构程,它将逆向工程、重构和正向工程和正向工
28、程组合起来,将合起来,将现存系存系统重新构造重新构造为新的形式。当新的形式。当实施施软件的再工程件的再工程时,软件理解件理解是再工程的基是再工程的基础和前提。和前提。38再工程的概念再工程的概念为什么要什么要进行再工程行再工程 维护一行源代码的代价可能是最初开发该行源代码代价的维护一行源代码的代价可能是最初开发该行源代码代价的14-20倍;倍;同时重新设计软件体系结构时使用了现代设计概念,它对同时重新设计软件体系结构时使用了现代设计概念,它对将来的维护会有很大的帮助;将来的维护会有很大的帮助;现有的程序版本可以作为软件原型使用,开发生产率可以现有的程序版本可以作为软件原型使用,开发生产率可以大
29、大高于平均水平;大大高于平均水平;用户具有较多使用该软件的经验,因此,能够很容易地搞用户具有较多使用该软件的经验,因此,能够很容易地搞清新的变更需求和变更的范围;清新的变更需求和变更的范围;另外,利用逆向工程和再工程的工具,可以使一局部工作另外,利用逆向工程和再工程的工具,可以使一局部工作自动化;自动化;在完成预防性维护的过程中还可以建立起完整的软件配置。在完成预防性维护的过程中还可以建立起完整的软件配置。39再工程的概念再工程的概念通常再工程包含:通常再工程包含:业务过程再工程、程再工程、软件再工件再工程程 业务过程再工程BPRBusiness Process Re-engineering,
30、也称业务过程重组定义业务目标、标示并评估现有的业务过程以及修订业务过程以更好满足业务目标,这一局部通常由咨询公司的业务专家完成软件再工程包含库存目录分析、文档重构、逆向工程、程序和数据重构以及正向工程。这一局部通常由软件工程师完成 45软件再工程件再工程过程程 在在业务过程被分析清楚后,可以程被分析清楚后,可以对软件件实施再施再工程,整个工程,整个软件再工程件再工程过程模型如以下程模型如以下图 46软件再工程件再工程过程程库存目存目录分析分析库存目录包含关于每个应用系统的基本信息例如,应用系统的名字,最初构建它的日期,已做过的实质性修改次数,过去18个月报告的错误,用户数量,安装它的机器数量,
31、它的复杂程度,文档质量,整体可维护性等级,预期寿命,在未来36个月内的预期修改次数,业务重要程度等。下述3类程序有可能成为预防性维护的对象:预定将使用多年的程序、当前正在成功地使用着的程序和在最近的将来可能要做重大修改或增强的程序。47软件再工程件再工程过程程文档重构文档重构建立文档非常消耗时间,不可能为数百个程序都重新建立文档。如果一个程序是相对稳定的,而且可能不会再经历什么变化,那么,让它保持现状。为了便于今后的维护,必须更新文档,但只针对系统中当前正在修改的那些局部建立完整文档。如果某应用系统是完成业务工作的关键,而且必须重构全部文档,则仍然应该设法把文档工作减少到必需的最小量。48软件
32、再工程件再工程过程程逆向工程逆向工程软件的逆向工程是分析程序以便在比源代码更高的抽象层次上创立出程序的某种表示的过程,逆向工程工具从现存的程序代码中抽取有关数据、体系结构和处理过程的设计信息。49软件再工程件再工程过程程代代码重构重构某些老程序具有比较完整、合理的体系结构,但是,个体模块的编码方式却是难于理解、测试和维护的。在这种情况下,可以重构可疑模块的代码。为了完成代码重构活动,首先用重构工具分析源代码,标注出和结构化程序设计概念相违背的局部。然后重构有问题的代码此项工作可自动进行。最后,复审和测试生成的重构代码以保证没有引入异常并更新代码文档。50软件再工程件再工程过程程数据重构数据重构
33、数据重构发生在相当低的抽象层次上,它是一种全范围的再工程活动。在大多数情况下,数据重构始于逆向工程活动,分解当前使用的数据体系结构,必要时定义数据模型,标识数据对象和属性,并从软件质量的角度复审现存的数据结构。51软件再工程件再工程过程程正向工程正向工程正向工程过程应用软件工程的原理、概念、技术和方法来重新开发某个现有的应用系统。在大多数情况下,被再工程的软件不仅重新实现现有系统的功能,而且参加了新功能和提高了整体性能。52逆向工程逆向工程 逆向工程是把逆向工程是把软件源程序复原件源程序复原为软件文档或件文档或软件件设计的的过程。通程。通过逆向工程,可以从更高的抽象度来逆向工程,可以从更高的抽
34、象度来观察察软件。件。抽象度的多少可由抽象的抽象度的多少可由抽象的层次,文档的完整性,工具等次,文档的完整性,工具等因素决定。因素决定。逆向工程来源于硬件世界。硬件厂商逆向工程来源于硬件世界。硬件厂商总想弄到想弄到竞争争对手手产品的品的设计和制造和制造“奥秘奥秘。但是又得不到。但是又得不到现成的档案,成的档案,只好拆卸只好拆卸对手的手的产品并品并进行分析,企行分析,企图从中从中获取有价取有价值的的东西。西。软件的逆向工程在道理上与硬件相似。但在很多件的逆向工程在道理上与硬件相似。但在很多时候,候,软件的逆向工程并不是件的逆向工程并不是针对竞争争对手的,而是手的,而是针对自己自己公司多年前的公司
35、多年前的产品。期望从老品。期望从老产品中提取系品中提取系统设计、需、需求求说明等有价明等有价值的信息。的信息。53逆向工程逆向工程逆向工程导出的信息可分为四个抽象层次逆向工程导出的信息可分为四个抽象层次实现级:包括程序的抽象语法树、符号表等信息;实现级:包括程序的抽象语法树、符号表等信息;结构级:包括反映程序分量之间相互依赖关系的信息,结构级:包括反映程序分量之间相互依赖关系的信息,如调用图、结构图等;如调用图、结构图等;功能级:包括反映程序段功能及程序段之间关系的信功能级:包括反映程序段功能及程序段之间关系的信息;息;领域级:包括反映程序分量或程序诸实体与应用领域领域级:包括反映程序分量或程
36、序诸实体与应用领域概念之间对应关系的信息。对于一项具体的维护任务,概念之间对应关系的信息。对于一项具体的维护任务,一般不必导出所有抽象级别上的信息。如代码重构任一般不必导出所有抽象级别上的信息。如代码重构任务,只需获得实现级信息即可。务,只需获得实现级信息即可。54逆向工程逆向工程根据源程序的类别不同,逆向工程还可以分为:根据源程序的类别不同,逆向工程还可以分为:对用户界面的逆向工程对用户界面的逆向工程对数据的逆向工程对数据的逆向工程对理解的逆向工程对理解的逆向工程57小结小结软件维护是指软件系统交付使用以后,为了改正错误或满足新的需求软件维护是指软件系统交付使用以后,为了改正错误或满足新的需
37、求而修改软件的过程。按照不同的维护目的,维护工作可分成而修改软件的过程。按照不同的维护目的,维护工作可分成4 4类类:完善完善性维护、纠错性维护、适应性维护、预防性维护性维护、纠错性维护、适应性维护、预防性维护软件维护的特点:结构化维护与非结构化维护差异巨大、与软件维护软件维护的特点:结构化维护与非结构化维护差异巨大、与软件维护有关的问题多、软件维护的代价高。有关的问题多、软件维护的代价高。软件维护的过程:维护团队根据时间的不同软件维护的过程:维护团队根据时间的不同,可以分为短期团队和长可以分为短期团队和长期团队,按一定流程进行软件维护工作,软件维护工作不仅是技术性期团队,按一定流程进行软件维
38、护工作,软件维护工作不仅是技术性的,它还需要大量的管理工作与之相配合。的,它还需要大量的管理工作与之相配合。软件的可维护性对于延长软件的生存期具有决定的意义;因此必须考软件的可维护性对于延长软件的生存期具有决定的意义;因此必须考虑如何才能提高软件的可维护性。虑如何才能提高软件的可维护性。“软件再工程软件再工程,是提高软件可维护性的一类重要的软件工程活动。,是提高软件可维护性的一类重要的软件工程活动。9、静夜四无、静夜四无邻,荒居旧,荒居旧业贫。5月月-235月月-23Sunday,May 14,202310、雨中黄叶、雨中黄叶树,灯下白,灯下白头人。人。18:42:5518:42:5518:4
39、25/14/2023 6:42:55 PM11、以我独沈久,愧君相、以我独沈久,愧君相见频。5月月-2318:42:5518:42May-2314-May-2312、故人江海、故人江海别,几度隔山川。,几度隔山川。18:42:5518:42:5518:42Sunday,May 14,202313、乍、乍见翻疑梦,相悲各翻疑梦,相悲各问年。年。5月月-235月月-2318:42:5518:42:55May 14,202314、他、他乡生白生白发,旧国,旧国见青山。青山。14 五月五月 20236:42:55 下午下午18:42:555月月-2315、比不了得就不比,得不到的就不要。、比不了得就不
40、比,得不到的就不要。五月五月 236:42 下午下午5月月-2318:42May 14,202316、行、行动出成果,工作出出成果,工作出财富。富。2023/5/14 18:42:5518:42:5514 May 202317、做前,能、做前,能够环视四周;做四周;做时,你只能或者最好沿着以脚,你只能或者最好沿着以脚为起点的射起点的射线向前。向前。6:42:55 下午下午6:42 下午下午18:42:555月月-239、没有失、没有失败,只有,只有暂时停止成功!。停止成功!。5月月-235月月-23Sunday,May 14,202310、很多事情努力了未必有、很多事情努力了未必有结果,但是不
41、努力却什么改果,但是不努力却什么改变也没有。也没有。18:42:5518:42:5518:425/14/2023 6:42:55 PM11、成功就是日复一日那一点点小小努力的、成功就是日复一日那一点点小小努力的积累。累。5月月-2318:42:5518:42May-2314-May-2312、世、世间成事,不求其成事,不求其绝对圆满,留一份缺乏,可得无限完美。,留一份缺乏,可得无限完美。18:42:5518:42:5518:42Sunday,May 14,202313、不知香、不知香积寺,数里入云峰。寺,数里入云峰。5月月-235月月-2318:42:5518:42:55May 14,2023
42、14、意志、意志坚强的人能把世界放在手中像泥的人能把世界放在手中像泥块一一样任意揉捏。任意揉捏。14 五月五月 20236:42:55 下午下午18:42:555月月-2315、楚塞三湘接,、楚塞三湘接,荆门九派通。九派通。五月五月 236:42 下午下午5月月-2318:42May 14,202316、少年十五二十、少年十五二十时,步行,步行夺得胡得胡马骑。2023/5/14 18:42:5518:42:5514 May 202317、空山新雨后,天气晚来秋。、空山新雨后,天气晚来秋。6:42:55 下午下午6:42 下午下午18:42:555月月-239、杨柳散和柳散和风,青山澹吾,青山澹
43、吾虑。5月月-235月月-23Sunday,May 14,202310、阅读一切好一切好书如同和如同和过去最杰出的人去最杰出的人谈话。18:42:5518:42:5518:425/14/2023 6:42:55 PM11、越是没有本、越是没有本领的就越加自命非凡。的就越加自命非凡。5月月-2318:42:5518:42May-2314-May-2312、越是无能的人,越喜、越是无能的人,越喜欢挑剔挑剔别人的人的错儿。儿。18:42:5518:42:5518:42Sunday,May 14,202313、知人者智,自知者明。、知人者智,自知者明。胜人者有力,自人者有力,自胜者者强。5月月-235
44、月月-2318:42:5518:42:55May 14,202314、意志、意志坚强的人能把世界放在手中像泥的人能把世界放在手中像泥块一一样任意揉捏。任意揉捏。14 五月五月 20236:42:55 下午下午18:42:555月月-2315、最具挑、最具挑战性的挑性的挑战莫莫过于提升自我。于提升自我。五月五月 236:42 下午下午5月月-2318:42May 14,202316、业余生活要有意余生活要有意义,不要越,不要越轨。2023/5/14 18:42:5518:42:5514 May 202317、一个人即使已登上、一个人即使已登上顶峰,也仍要自峰,也仍要自强不息。不息。6:42:55 下午下午6:42 下午下午18:42:555月月-23MOMODA POWERPOINTLorem ipsum dolor sit amet,consectetur adipiscing elit.Fusce id urna blandit,eleifend nulla ac,fringilla purus.Nulla iaculis tempor felis ut cursus.感感 谢谢 您您 的的 下下 载载 观观 看看专家告诉演讲完毕,谢谢观看!