2023年计算机考试资料软件工程.doc
《2023年计算机考试资料软件工程.doc》由会员分享,可在线阅读,更多相关《2023年计算机考试资料软件工程.doc(44页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、第五章考试要点自从 1968年初次提出软件工程一词以来,软件工程已成为计算机软件的一个重要分支和研究方向。软件工程是指应用计算机科学、数学及管理科学等原理,以工程化的原则和方法来解决软件问题的工程。其目的是提高软件生产率、提高软件质量、减少软件成本。一、软件工程基本概念初期的软件重要指程序。程序的开发采用个体工作方式,开发工作重要依赖于开发人员的个人技能和程序设计技巧。当时的软件通常缺少与程序有关的文档,软件开发的实际成本和进度往往与预计的相差甚远,软件的质量得不到保证,开发出来的软件经常不能使用户满意。随着计算机应用的需求不断增长,软件的规模也越来越大,然而软件开发的生产率远远跟不上计算机应
2、用的迅速增长。此外,由于软件开发时缺少好的方法指导和工具辅助,同时又缺少有关的文档,使得大量已有的软件难以维护。上述这些问题严重地阻碍了软件的发展,20世纪 60年代中期,人们把上述软件开发和维护中的各种问题称为“软件危机”。1968年在德国召开的 NATO 会议上,初次提出了“软件工程”一词,希望用工程化的原则和方法来克服软件危机。在此以后,人们开展了软件开发模型、开发方法、工具与环境的研究,提出了瀑布模型、演化模型、螺旋模型、喷泉模型等开发模型,出现了面向数据流方法、面向数据结构的方法、面向对象方法等开发方法,以及一批 CASE(computer aided software engine
3、ering)工具和环境。(一)软件生存周期如同人的一生要经历婴儿期、少年期、老年期直至死亡这样一个全过程同样,任何一个软件产品或软件系统也都要经历软件定义、软件开发、软件维护直至被淘汰这样一个全过程,我们把软件的这一全过程称为软件生存周期。软件定义、软件开发、软件维护等阶段还可分为若干个阶段,每个阶段相对独立又彼此有联系,上一阶段的工作结果是下一阶段工作的依据,下一阶段是上一阶段的进化,它更接近于问题的解。1.软件定义软件定义阶段重要解决的问题是待开发的软件要“做什么”,也就是要拟定软件的解决对象,软件与外界的接口,软件的功能和性能,界面以及有关的约束和限制。软件定义阶段通常可提成系统分析、软
4、件项目计划、需求分析等阶段。(1)系统分析这里讲的系统是指计算机系统,涉及计算机硬件、软件和使用计算机的人。系统分析的任务是拟定待开发软件的总体规定和合用范围,以及与之有关的硬件、支撑软件的规定。系统分析阶段的参与人员有用户、项目负责人、系统分析员。该阶段产生的文档可合并在软件项目计划阶段的文档(项目计划书)中。(2)软件项目计划软件项目计划的任务是拟定待开发软件的目的,对其进行可行性分析,并对资源分派、进度安排等做出合理的计划。软件项目计划阶段的参与人员有用户、项目负责人、系统分析员。该阶段所产生的文档有可行性分析报告、项目计划书。(3)需求分析需求分析的任务是拟定待开发软件的功能、性能、数
5、据、界面等规定,从而拟定系统的逻辑模型。需求分析阶段的参与人员有用户、项目负责人系统分析员。该阶段产生的文档有需求规约(requirements specification),习惯上称它为需求规格说明书。2.软件开发软件开发阶段重要解决的问题是该软件“怎么做”,涉及数据结构和软件结构的设计,算法设计,编写程序,测试,最后得到可交付使用的软件。软件开发阶段通常可提成软件设计、编码、软件测试等阶段。(1)软件设计软件设计通常还可提成概要设计和具体设计。概要设计的任务是模块分解,拟定软件的结构,模块的功能和模块间的接口,以及全局数据结构的设计。具体设计的任务是设计每个模块的实现细节和局部数据结构的设
6、计。概要设计阶段的参与人员有系统分析员和高级程序员,具体设计阶段的参与人员有高级程序员和程序员。设计阶段产生的文档有设计规约(design specification),也称为设计说明书,它也可分为概要设计说明书和具体设计说明书。根据需要还可产生数据说明书和模块开发卷宗。(2)编码编码的任务是用某种程序语言为每个模块编写程序。编码阶段的参与人员有高级程序员和程序员,产生的文档有程序清单。(3)软件测试软件测试的任务是发现软件中的错误,并加以纠正。软件测试阶段的参与人员通常由另一部门(或单位)的高级程序员或系统分析员承担,该阶段产生的文档有软件测试计划和软件测试报告。3.软件维护软件开发阶段结束
7、后,软件即可交付使用。软件的使用通常要连续几年甚至几十年,在整个使用期间,都也许由于某种因素而修改软件,这便是软件维护。引起修改软件的因素重要有三种:一是在软件运营过程中发现了软件中隐藏的错误而修改软件;二是为了适应变化了的环境而修改软件;三是为修改或扩充原有软件的功能而修改软件。因此软件维护的任务就是为使软件适应外界环境的变化、实现功能的扩充和质量的改善而修改软件。软件维护阶段的参与人员是维护人员,该阶段产生的文档有维护计划和维护报告。目前,软件生存周期各阶段的划分尚不统一,有的分得粗些,有的分得细些。许多场合软件开发阶段都是从需求分析阶段开始的。本书中,我们也将需求分析看作为软件开发的开始
8、阶段。(二)软件开发模型为了指导软件的开发,用不同的方式将软件生存周期中的所有开发活动组织起来,形成不同的软件开发模型。常见的软件开发模型有瀑布模型、演化模型、螺旋模型、喷泉模型等。瀑布模型如下图所示,它是 1970年由 W.Royce 提出的。该模型给出了软件生存周期各阶段的固定顺序,上一阶段完毕后才干进入到下一阶段,整个过程就像流水下泻,故称之为瀑布模型。图中的虚线部分表达在某一阶段发现错误时,其错误也许是由上一阶段导致的,因此开发过程也许要反馈到上一阶段。在瀑布模型中,各阶段结束后,都要进行严格的评审。(三)软件开发方法软件开发过程模型规定软件开发活动的组合应用方式,要保证开发活动的高质
9、量,还需要有相应的软件开发方法作为技术支持。近 2023来,软件工作者研制出了许多工程化的软件开发方法,例如 70年代初提出的用于编写程序的结构化程序设计方法,的确起到了提高效率,减少错误的效果。但是 70年代中期,软件工作者结识到编写程序仅仅是软件开发的一个环节,而合理地建立系统结构比编定程序更为重要。所以研究的重点前移到设计阶段,出现了设计阶段的结构化设计(SD)方法和 JACKSON等方法,到了 70年代后期,人们又发现事先对用户的规定进行分析更为重要,故又把重点前移到分析阶段。出现了用于分析阶段的结构化分析(SA)方法、结构化分析与设计技术(SADT)等。随着计算机技术的迅速发展,在
10、80年代初期的实时、并发和网络等软件的开发过程中,特别是在第五代计算机研究工作中,又提出了面向对象的设计方法。现在流行的方法有多种,它们的合用范围也各不相同。有的合用于一般的数据解决系统,如 SA、SD(两者统称为结构化分析与设计方法,即 Yourdon方法)、JACKSON方法;有的合用于大型的复杂系统,如 SADT 技术;有的合用于实时事务解决系统,如 FSM方法;有的合用于并发软件系统,如 PETRI 网方法;作为 90年代代表作的面向对象方法,其应用已几乎遍布各个领域。这些方法除了合用范围不同外,方法形成的基础、解决规则和对所开发软件风格的规定等都各有侧重。用什么方法来说明用户的规定、
11、用什么方法来设计软件以及用什么方法对软件进行测试和维护,直接影响所开发软件的质量。(四)软件开发工具初期的软件开发除了一般的程序设计语言外尚缺少工具的支持,致使编程工作量大,质量和进度却难以保证,导致人们将很多的精力和时间花费在程序的编制和调试上;相比之下,在更重要的软件的需求和设计上反而得不到必要的精力和时间投入。软件开发工具的发展促进了软件开发的高速度和高质量。工具的发展是从单项工具的开发逐步走向集成的工具发展的。同时,软件开发方法的有效应用也必须得到相应工具的支持,否则方法将难以有效的实行。工具的完善和发展将促进软件开发的进步和完善。原型化方法的实行基础就是得到了开发工具的支持。快速原型
12、化之所以可以实现的基础就是原型化人员在快速建模时得到了工具的支持,否则原型化方法是无法实行的。(五)软件开发环境软件工程环境或称软件开发环境是全面支持软件开发全过程的软件工具集合。这些软件工具按照一定的方法或模式组合起来,并能支持软件开发生命周期的各个阶段和各项任务的完毕。CASE,即计算机辅助软件工程环境是当前软件开发环境中富于特色的研究工作和发展方向,它的成功将最大限度地减少软件工程的技术难度并使软件开发的质量得到保证。二、结构化生命周期方法结构化分析与设计方法在软件工程中应用已很普遍,并且越来越成熟。有许多大、中型项目都采用了这种方法进行开发并取得了显著的成果。按 B.W.Boehm的描
13、述,瀑布模型的的软件生命周期可划分七个阶段:系统需求分析、软件需求分析、概要分析、具体设计、编码、测试和运营维护。(一)系统需求“系统需求”涉及:问题定义、可行性研究及软件计划。1.问题定义软件开发的第一步就是进行问题定义。问题定义阶段必须回答的关键问题:“软件要解决的问题是什么?”假如不知道问题是什么就试图解决这个问题,显然是盲目的,只会白白浪费时间和金钱,最终得出的结果很也许是毫无意义的。尽管确切地定义问题的必要性是十分明显的,但是在实践中它却也许是最常被忽视的一个环节。这里所说的问题,就是指用户的基本规定。说得通俗些,问题定义事实上就是了解用户到底要建立什么系统,并拟定分析员下一步应当做
14、什么。因此,问题定义的来源是用户。通过问题定义阶段的工作,系统分析员应当提出关于问题性质、工程目的和规模的书面报告。这一阶段的分析员应尽也许站在较高的角度去抽象、概括所要干的事情,不要拘泥于问题实现的细节。尽管用户也许总是习惯于这样做,但分析员在这一阶段必须超脱出来,居高临下鸟瞰系统的全貌。通过对系统的实际用户和使用部门负责人的访问调查,分析员扼要地写出他对问题的理解,并在使用部门负责人的会议上认真讨论这份书面报告,澄清模糊不清的地方,改正理解不对的的地方,最后得出一份双方都满意的文档。当用户的规定不是很多并且不太复杂时,一两个分析员用上一两天就可以完毕这一工作了。但当系统比较大,且复杂时,恐
15、怕就要组织一个问题定义小组,花上一两个星期,甚至数月来定义用户的问题。假如分析员和用户及使用部门的负责人对所要解决的问题取得完全一致的见解,并且使用部门的负责人批准开发工程继续进行下去,那么开发工程将转入生命周期的下一个阶段可行性研究。2.可行性研究并不是所有问题都有简朴明显的解决办法,事实上,许多问题不能在预定的系统规模之内解决。假如问题没有可行的解,那么花费在这项开发工程上的任何时间、资源、人力和经费和都是无谓的浪费。可行性研究的目的在于用最小的代价拟定在问题定义阶段所拟定的系统的目的和规模是否现实,所拟定的问题是否可以解决,系统方案在经济上、技术上和操作上是否可以接受。可行性研究着重对如
16、下具体方案考虑:(1)经济可行性。估计开发费用以及新系统也许带来的收益,将两者进行权衡,看结果是否可以接受。(2)技术可行性。对规定的功能、性能以及限制条件进行分析,是否可以做成一个可接受的系统。所考虑的因素通常还应涉及开发的风险,是否可以得到需要的软件和硬件资源和一个纯熟的有能力的开发队伍,与系统开发有关的技术是否足以支持系统的研制。技术可行性的估计,需要有经验的人员去完毕。(3)操作可行性。判断系统的操作方式在该用户组织内是否可行。分析、设计人员应以新系统的目的和作用范围为依据提出一种以上的设计方案,从技术可行性、经济可行性、操作可行性等方面进行比较,并选择出综合最优的方案。根据可行性研究
17、结果要做出的决定是:是否继续按预定目的进行这项开发工程,可行性分析人员必须清楚地表白他对这个关键性决定的建议。假如认为值得继续进行这项开发工程,则应提供选择一种最佳的解法并说明理由。可行性分析是在问题的目的和约束之间的一种权衡,还也许有的结果则是修改目的或放宽约束。3.软件计划分析人员应当为推荐的系统草拟一份软件计划,其中描述的是为了成功地进行一个软件项目,其所需要做的工作、需要的资源、需要的工作量和费用以及应遵循的进度安排。软件计划由两项任务组成:分析和估算。分析是对系统内各软件功能的界线的划定。估算是指根据已有的定性数据和已往的经验对系统开发的资源、费用和进度进行定量的估计。软件开发项目的
18、进度安排可以从两种观点来考虑:一是项目的交付日期已定,负责开发工作的软件机构被限制在一个规定的时间范围内分派其工作量。二是项目最后的交付日期由软件机构自已拟定,可以从最佳的运用各种资源的角度出发来分派工作量,项目最后的交付日期通过对软件各部分仔细分析后才拟定。在多数项目中,碰到的往往是第一种情况。软件计划的阅读者可以涉及软件主管部门、用户和技术人员。所拟定的成本与进度可供主管部门复审。它同时也给出了整个软件生命周期的基本成本预算的进度安排。(二)软件需求分析软件需求分析工作是软件生存期中重要的一步,也是决定性的一步。只有通过软件需求分析,才干把软件功能和性能的总体概念描述为具体的软件需求规格说
19、明,从而奠定软件开发的基础。软件需求分析工作也是一个不断结识和逐步细化的过程。该过程将软件设计阶段所拟定的软件范围(工作域)逐步细化到可具体定义的限度,并分析出各种不同的软件元素,然后为这些元素找到可行的解决方法。制定软件的需求规格说明不只是软件开发人员的事,用户也起着至关重要的作用。用户必须对软件功能和性能提出初步规定,并澄清一些模糊概念。而软件分析人员则要认真了解用户的规定,细致地进行调查分析,把用户“做什么”的规定最终转换成一个完全的、精细的软件逻辑模型并写出软件的需求规格说明,准确地表达用户的规定。1.软件需求分析任务需求分析所要做的工作是进一步描述软件的功能和性能,拟定软件设计的限制
20、和软件同其他系统元素的接口细节。定义软件的其他有效性需求。分析员通过需求分析,逐步细化对软件的规定,描述软件要解决的数据域,并给软件开发提供一种可转化为数据设计、结构设计和过程设计的数据与功能表达。在软件完毕后,制定的软件需求规格说明还要为评价软件质量提供依据。需求分析阶段研究的对象是软件项目的用户规定。需要注意的是,必须理解用户的各项规定,但又不能全盘接受所有的规定。由于并非所有用户规定都是合理的。对其中模糊的规定还需要澄清,然后才干决定是否可以采纳。对于那些无法实现的规定应向用户做充足的解释,以求得谅解。准确地表达所接受的用户规定,是需求分析的另一个重要方面。只有通过确切描述的软件需求才干
21、成为软件设计基础。通常软件开发项目是要实现目的系统的物理模型,即拟定待开发软件系统的系统元素,并将功能和数据结构分派到这些系统元素中。它是软件实现的基础。但是目的系统的具体物理模型是由它的逻辑模型经实例化,即具体到某个业务领域而得到的。与物理模型不同,逻辑模型忽视实现机制与细节,只描述系统要完毕的功能和要解决的数据。作为目的系统的参考,需求分析的任务就是借助于当前系统的逻辑模型导出目的系统的逻辑模型,解决目的系统的“做什么”的问题。(1)获得当前系统的物理模型。当前系统也许是需要改善的某个已在计算机运营的数据解决系统,也也许是一个人工的数据解决过程。在这一步一方面分析、理解当前系统是如何运营的
22、,了解当前系统的组织机构、输入输出、资源运用情况和平常数据解决过程,并用一个具体模型来反映自己对当前系统的理解。这一模型应客观地反映现实世界的实际情况。(2)抽象出当前系统的逻辑模型。在理解当前系统“如何做”的基础上,抽取其“做什么”的本质,从而从当前系统的物理模型抽象出当前系统的逻辑模型。在物理模型中有许多物理因素,随着分析工作的进一步,有些非本质的物理因素就成为不必要的承担,因而需要对物理模型进行分析,区分出本质的和非本质的因素,去掉那些非本质的因素即可获得反映系统本质的逻辑模型。(3)建立目的系统的逻辑模型。分析目的系统与当前系统逻辑上的差别,明确目的系统统到底要“做什么”,从当前系统的
23、逻辑模型导出目的系统的逻辑模型。(4)为了对目的系统做完整的描述,还需要对得到的逻辑模型做一些补充。说明目的系统的用户界面。根据目的系统所处的应用环境及它与外界环境的互相关系,研究所有也许与它发生联系和作用的部分,从而决定人机界面。说明至今尚未具体考虑的细节。这些细节涉及系统的启动和结束、犯错解决、系统的输入输出和系统性能方面的需求。其他。例如系统的其他必须满足的性能和限制等等。2.需求分析的过程需求分析阶段的工作,可以提成以下 4个方面:对问题的辨认、分析与综合、制定规格说明和评审。(1)问题辨认一方面系统分析人员要研究计划阶段产生的可行性分析报告(假如有的话)和软件项目实行计划。重要是从系
24、统的角度来理解软件并评审用于产生计划估算的软件范围是否恰当。拟定对目的系统的综合规定,即软件的需求。并提出这些需求实现条件,以及需求应达成的标准。也就是规定所开发软件做什么,做到什么限度。这些需求涉及:功能需求:列举出所开发软件在职能上应做什么。这是最重要的需求。性能需求:给出所开发软件的技术性能指标,涉及存储容量限制、运营时间限制、安全保密性等。环境需求:这是对软件系统运营时所处环境的规定。例如在硬件方面,采用什么机型、有什么外部设备、数据通信接口等等。在软件方面,采用什么支持系统运营的系统软件(指操作系统、网络软件、数据库管理系统等)。在使用方面,需要使用部门在制度上、操作人员的技术水平上
25、应具有什么样的条件等等。可靠性需求:各种软件在运营时,失效的影响各不相同。在需求分析时,应对所开发软件在投入运营后不发生故障的概率,按实际的运营环境提出规定,对于那些重要的软件,或是运营失效会导致严重后果的软件,应当提出较高的可靠性规定,以期在开发的过程中采用必要的措施,使软件可以高度可靠地稳定运营,避免因运营事故而带来的损失。安全保密规定:工作在不同环境的软件对其安全,保密的规定显然是不同的。应当把这方面的需求恰本地做出规定,以便对所开发的软件给予特殊的设计,使其在运营中其安全面的性能得到必要的保证。用户界面需求:软件与用户界面的和谐性是用户可以方便、有效、快乐地使用该软件的关键之一。从市场
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 2023 计算机 考试 资料软件 工程
限制150内