您好,欢迎访问三七文档
当前位置:首页 > 建筑/环境 > 工程监理 > 第1章_软件工程概述
2019/8/81第1章软件工程概述【本章重点】软件的概念和特点、软件工程的框架及基本原则【本章用途】本章论述的有关软件工程的基本概念、原理及相关知识能帮助读者对软件工程的原理和方法有一个概括的、本质的认识。2019/8/821.1软件的概念、特点与分类许多人把软件这个术语等同于计算机程序,其实这种理解是很狭隘的。软件是程序和所有使程序正确运行所需要的相关文档和配置信息。一个软件系统通常包含大量独立的程序、用于设置这些程序的配置文件、描述系统结构的系统文档和如何使用该系统的用户文档,以及告知用户下载最新产品信息的Web站点。2019/8/83软件具有如下特点:–软件是一种逻辑实体,不是具体的物理实体。–软件产品的生产主要是研制。–软件具有“复杂性”,其开发和运行常受到计算机系统的限制。–软件成本昂贵,其开发方式目前尚未完全摆脱手工生产方式。–软件不存在磨损和老化问题,但存在退化问题。2019/8/84时间失效率时间失效率理想曲线实际曲线图1.1给出了硬件的失效率曲线,它是一个U型曲线(即浴盆曲线),说明硬件随着使用时间的增加失效率急剧上升。图1.2所描述的软件失效率曲线,它没有U型曲线的右半翼,表明软件随着使用时间的增加失效率降低,因为软件不存在磨损和老化问题,然而存在退化问题。图1.1图1.22019/8/85软件产品有以下两类:(1)通用软件产品这类软件产品由软件开发机构制作,在市场上公开销售,可以独立使用。这类软件产品有:数据库软件、字处理软件、绘图软件以及工程管理工具等。(2)定制软件产品这类软件产品受特定的客户委托,由软件承包商专门为这类客户开发。这类软件有:电子设备的控制系统、特定的业务处理系统和空中交通管制系统等。这两类产品的一个重要区别在于:在通用软件中,软件描述由开发者自己完成,而定制软件产品的软件描述通常是由客户给出,开发者必须按客户要求进行开发。2019/8/86软件工程是一类工程。工程是将理论和知识应用于实践的科学。就软件工程而言,它借鉴了传统工程的原则和方法,以求高效地开发高质量软件。其中应用了计算机科学、数学和管理科学。计算机科学和数学用于构造模型与算法,工程科学用于制定规范、设计范型、评估成本及确定权衡,管理科学用于计划资源、对质量和成本进行管理。早期软件开发的经验是:非正规的软件开发并不奏效。多数软件项目有时甚至要推迟几年才能完成,而且比预计的费用高,不可靠,难以维护,总之,做得很差。软件开发陷入危机,结果是硬件成本在下降而软件成本却呈快速增长之势,因而必须要有新的技术和方法来控制大型软件系统固有的复杂性。1.2软件工程概述2019/8/8770年代初,自“软件工程”这一概念提出以来,主要围绕软件过程以及软件复用,开展了有关软件生产技术和软件生产管理的研究与实践。其主要成果有:提出了应用广泛的面向对象语言以及相关的面向对象方法,大力开展了计算机辅助软件工程的研究与实践。尤其是近几年来,针对软件复用及软件生产,软件构件技术以及软件质量控制技术、质量保证技术得到了广泛的应用。目前各个软件企业都十分重视资质认证,并想通过这些工作进行企业管理和技术的提升。2019/8/88IEEE【IEE93】给出了软件工程的定义:“把系统的、规范的、可度量的方法应用于软件的开发、运行和维护过程,即将工程应用于软件;并研究以上实现的途径”2019/8/89软件工程(SoftwareEngineering)的框架可概括为:目标、过程和原则。(1)软件工程目标是生产具有正确性、可用性以及开销合宜的产品。正确性指软件产品达到预期功能的程度。可用性指软件基本结构、实现及文档为用户可用的程度。开销合宜是指软件开发、运行的整个开销满足用户要求的程度。2019/8/810(2)软件工程过程是生产一个最终能满足需求且达到工程目标的软件产品所需要的步骤。软件工程过程主要包括开发过程、运作过程、维护过程。它们覆盖了需求、设计、实现、确认以及维护等活动。2019/8/811(3)软件工程的原则是指围绕工程设计、工程支持以及工程管理在软件开发过程中必须遵循的原则。四项基本原则:选取适宜的开发范型。采用合适的设计方法。提供高质量的工程支持。重视开发过程的管理。2019/8/8121.3关于软件工程的问题1.3.1软件工程不同于计算机科学从本质上讲,计算机科学研究的是构成计算机和软件系统基础的有关理论和方法,而软件工程则研究软件制作中的实际问题。正如电子工程师必须具有一定的物理学知识一样,软件工程人员同样必须具有一定的计算机科学知识。理论上,所有软件工程都应该以计算机科学理论作为坚实的基础,但实际情况并非如此。软件工程人员常常必须要用特定的方法去开发软件。对于实际、复杂的问题,计算机科学的经典理论不可能总是适用的,这时就需要应用软件工程的方法来解决。2019/8/8131.3.2软件工程不同于系统工程系统工程应该是基于计算机的系统工程,研究由软件起主导作用的、有关复杂系统的开发和进化的方方面面,包括硬件开发、系统决策、过程设计、系统实施和软件工程等。系统工程人员要做的是描述这个系统,定义总的体系结构,然后集成各个组件以完成整个系统。他们较少关注系统各组件(硬件、软件等)的工程问题。系统工程的产生比软件工程要早。随着软件在系统中的比重不断增大,软件工程技术正被应用于系统工程过程之中。2019/8/8141.3.3软件工程不同于传统工程软件工程是更广泛的系统工程的一部分。软件是非物质的,经典的数学模型只适用于一部分而不是全部的软件。软件工程不必一味地模仿传统工程,它们是完全不同的。软件设计者必须做好准备去开发能适应环境变化的软件。这是软件应该具备的性质。也是软件工程不同于传统工程的地方。2019/8/8151.3.4软件工程不同于信息系统工程信息系统是应用软件的一个分支。因为它的应用面极其广泛,市场前景巨大,如管理信息系统(MIS)、企业资源计划系统(ERP)、办公自动化系统(OA)、金税(税务)系统、金关(海关)系统、金卫(医疗卫生)系统、保险系统、金融系统、证券系统、港口系统、民航系统、物流系统、公安系统、人口普查系统、电信计费系统、数字化城市系统等。信息系统工程是专门研究信息系统建设的工程,它是软件工程的一个分支,或者说它是软件工程的一部分。信息系统建设除了需要遵守软件工程的普遍原理和方法之外,还要遵守自己的特殊原理和方法,所以在讨论软件工程时也附带讨论一下信息系统工程。信息系统工程是一门新兴的工程学科,目前还不十分成熟,正处在发展之中,很多名词和定义还不规范,需要人们进一步探索。2019/8/8161.3.5软件工程不只是程序设计复杂问题需要软件工程,单靠程序设计无法解决复杂问题。复杂系统必须在编程之前进行设计。像建筑业一样,在建造复杂系统之前必须进行结构设计。必须用抽象和“分治”的方法对系统进行模块化。在程序员编写代码之前,对每个模块都要进行详细说明,并且必须定义与其他模块的接口。在设计一个系统之前,软件工程师必须了解它的需求。这就意味着必须做需求分析,而且必须用某种建模语言说明。最终,软件工程还是一个团队活动,必须对团队进行管理。因此,项目管理(projectmanagement)对软件工程是有影响的。总之,软件工程为系统提供一个体系结构的解决方案,包括设计体系结构组件,将组件集成为一个可操作的系统,项目管理等。软件工程是一门精妙的学问,程序设计只是其中一项有用的技能。2019/8/8171.3.6软件工程涉及的人员2019/8/8181.3.7什么是好的软件表1.1优良软件具有的属性产品特性含义可维护性软件必须能够不断进化以满足客户的需求变化,这是软件产品最根本的特性,因为工作环境是不断变化的,软件也必然要跟着变化可依赖性软件可依赖性还包括一系列特性,包括可靠性、保密性、安全性。可靠的软件在系统失败的情况下,也不会导致人员伤亡和经济损失有效性软件不要浪费内存和处理器等系统资源,因而有效性应包括响应时间、处理时间、内存利用率等方面可用性软件必须具备可用性。必须是用户不用特殊的努力就能操作。即软件必须具备相似的用户界面和充分的说明文档2019/8/8191.3.8软件工程所面临的主要问题(1)多样性的挑战(2)交付上的挑战(3)信任的挑战2019/8/8201.4软件工程的基本原理(1)用分阶段的生命周期计划严格管理(2)坚持进行阶段评审(3)实行严格的产品控制(4)采纳现代程序设计技术(5)结果应能清楚地审查(6)开发小组的人员应少而精(7)承认不断改进软件工程实践的必要性2019/8/8211.5软件的开发方法软件开发方法就是软件开发所遵循的办法和步骤,以保证所得到的运行系统和支持的文档满足质量要求。软件开发方法有很多种,其中,针对系统分析和设计活动的软件开发方法和针对系统全局的软件开发方法尤为重要。下面简略地介绍其中的四种软件开发方法。2019/8/8221.5.1结构化开发方法(1)结构化分析的步骤结构化分析(structuredanalysis,简称SA)与所有的软件分析方法一样,也是一种模型的确立活动。SA方法就是使用独有的符号,来确立描绘信息(数据和控制)流和内容的模型,划分系统的功能和行为,以及其他为确立模型不可缺少的描述。2019/8/8231.5.1结构化开发方法结构化分析基本步骤:①构造数据流模型:根据用户当前需求,在创建实体—关系图的基础上,依据数据流图(DFD)构造数据流模型。②构建控制流模型:一些应用系统除了要求用数据流建模外,通过构造控制流图(CFD),构建控制流模型。③生成数据字典(DD):对所有数据元素的输入、输出、存储结构,甚至是中间计算结果进行有组织的列表。目前一般采用CASE的“结构化分析和设计工具”来完成。④生成可选方案,建立需求规约:确定各种方案的成本和风险等级,据此对各种方案进行分析,然后从中选择一种方案,建立完整的需求规约。2019/8/824(2)结构化设计步骤结构化设计是一种面向数据流的设计方法,就是采用最佳的可能方法设计系统的各个组成部分以及各成分之间的内部联系的技术,目的在于提出满足系统需求的最佳软件的结构,完成软件层次图或软件结构图。2019/8/825结构化设计步骤:①首先研究、分析和审查数据流图。从软件的需求规格说明中弄清数据流加工的过程。②然后根据数据流图决定问题的类型。数据处理问题有两种典型的类型:变换型和事务型。针对两种不同的类型分别进行分析处理。③由数据流图推导出系统的初始结构图。也就是把数据流图映射到软件模块结构,设计出模块结构的上层。④利用一些试探性原则来改进系统的初始结构图,直到得到符合要求的结构图为止。即在数据流图的基础上逐步分解高层模块,设计中下层模块,并对软件模块结构进行优化,最终得到更为合理的软件结构。⑤描述模块接口。⑥修改和补充数据词典。⑦制定测试计划。2019/8/8261.5.2模块化开发方法模块化程序设计方法就是把一个待开发的软件系统分解成若干可单独命名和编址的较为简单的部分,称为模块(modules)。每个模块分别独立地开发、测试,最后再组装出整个软件系统。这种开发方法是对复杂的系统“分而治之”,“各个击破”,这种方法不仅可以将软件系统开发的复杂性在分解过程中降低,便于修改、维护,而且还容易实现同一个系统不同部分的并行开发,从而提高了软件的生产效率。2019/8/827将模块定义为多大较合适,下面五条标准可供参考:(1)模块可分解性:如果一种设计方法提供了将问题分解成子问题的系统化机制,它就能降低整个系统的复杂性,从而实现一种有效的模块化解决方案。(2)模块可组装性:如果一种设计方法使现存的(可复用的)设计模块能够被组装成新系统,它就能提供一种不用一切从头开始的模块化解决方案。(3)模块可理解性:如果一个模块可以作为一个独立的单位(不用参考其他模块)被理解,那么它就易于构造和修改。(4)模块连续性:如果对系统需求的微小修改只导致对单个模块而不是对整个系统的修改,则修改
本文标题:第1章_软件工程概述
链接地址:https://www.777doc.com/doc-203043 .html