软件开发项目的前期准备.ppt
第1章 软件开发项目的前期准备,【本章引言】软件开发在整个计算机软件的生存周期中是最重要的一环。如何高效、高质的开发成功的软件产品一直是软件工程师们一直追求的目标。经过半个多世纪的研究与探索,人们在计算软件开发领域已经积累了丰富的经验与成果。【教学目标】掌握计算机软件的概念与计算机软件的基本分类;掌握软件生存周期划分与相关档案 的内容;掌握常用软件开发模型;掌握计算机软件开发方法。,第一章 软件开发项目的前期准备,1.1 计算机软件概述 1.2 软件的生存周期 1.3 软件开发常用模型 1.4 软件开发方法和软件开发工具,1.1 计算机软件概述,1.1.1 计算机软件概念 1.1.2 软件的分类 1.1.3 软件工程的历史及发展,1.1 计算机软件概述,软件是一个完整的计算机系统中与硬件相互依存的另一部分,它是包括程序,数据及其相关文档的完整集合。其中,程序是按事先设计的功能和性能要求执行的指令序列;数据是使程序能正常操纵信息的数据结构;文档是与程序开发,维护和使用有关的图文材料。,1.1.1 计算机软件概念,软件是计算机系统中与硬件相互依存的另一部分,它是包括程序,数据及其相关文档的完整集合。计算机软件是指计算机程序以及解释和指导使用程序的文档的总和。计算机程序包括源程序和目标程序。,1.1.1 计算机软件概念,源程序是指用高级语言或汇编语言编写的程序,目标程序是指源程序经编译或解释加工以后,语言编写的程序,目标程序是指源程序经编译或解释加工以后可以由计算机直接执行的程序。文档是指用自然语言或者形式化语言所编写的文字资料和图表,用来描述程序的内容、组成、设计、功能规格、开发情况、测试结果及使用方法。,1.1.1 计算机软件概念,软件开发的特点是:(1)由于软件并不是实际存在的物理形态 它是一种抽象的逻辑过程,是一种逻辑实体,这个特点使它与其它工程对象有着明显的差异。人们可以把它记录在纸上、内存、和硬盘、光盘上,但却无法看到软件本身的形态,必须通过观察、分析、思考、判断,才能了解它的功能、性能等特性。,1.1.1 计算机软件概念,(2)软件的生产过程也非常特殊,同我们传统意义里的普通工厂里的加工不同的是,软件更像是一种纯粹的脑力劳动,同第一个特点一样它没有明显的物理加工过程。(3)由于软件产品其实是一种抽象的逻辑存在,所以在软件的运行和使用期间,没有硬件那样的机械磨损,设施老化问题。,1.1.1 计算机软件概念,任何物理设备在运行和使用中,都有一个大致趋势相同的失效率曲线。即为如图1-1(a)所示的型曲线(即浴盆曲线)。在这个曲线里边我们可以看出随着使用时间的增加设备的失效率主要是由磨损用坏造成的。而软件的情况与此不同,由于其固有的特性,本身不存在磨损和老化问题,即便是他的载体出现型曲线,软件本身仍然可以便利的移到另一台载体上边。然而同物理设备不同的是它存在退化问题,说着时间的增加,软件本身会出现落伍的现象,因此必须要对软件本身进行一次或多次修改(维护),如图1-1(b)所示。而这些修改又不可避免的引入错误,导致软件失效率升高,从而似的软件退化。当修改的成本变得难以接受时,软件就被抛弃。,1.1.1 计算机软件概念,图1-1 计算机软件失效率曲线,1.1.1 计算机软件概念,(4)软件的开发和运行不是完全由软件本身的技术实现的,它常常还受到计算机系统的限制,对计算机系统有着不同程度的依赖性。软件对硬件和环境有着不同程度的依赖性。这导致了软件移植的问题,1.1.1 计算机软件概念,(5)软件本身是一件结构非常复杂的产品。软件的复杂性来自于两个方面:一是来自它所反映的实际问题的复杂性(即需要解决问题的复杂性)二是来自软件本身设计程序逻辑结构的复杂性,1.1.1 计算机软件概念,(6)软件的成本问题。软件开发成本主要指软件开发过程中所花费的工作量及相应的代价。另外,软件也没有一个明显的制造过程,它的开发成本是以一次性开发过程所花费的代价来计算的。软件的研制工作需要投入大量的、复杂的、高强度的脑力劳动,它的成本是比较高的。,1.1.1 计算机软件概念,(7)软件开发出来时要给“人”使用的,所以软件不可避免地要具备人的社会属性。相当多的软件工作涉及到社会因素。许多软件的开发和运行涉及机构、体制及管理方式等问题,甚至涉及到人的观念和人们的心理。这些问题都将直接影响项目的成败。,1.1.2 软件的分类,软件是计算机的灵魂,没有软件的计算机就如同没有磁带的录音机和没有录像带的录像机一样,与废铁没什么差别。它使计算机具有非凡的灵活性和通用性。也正是这一原因,决定了计算机的任何动作都离不开由人安排的指令。,1.1.2 软件的分类,1.按软件的功能进行划分:一般把软件按功能分为两大类:应用软件和系统软件。(1)应用软件(2)系统软件,1.1.2 软件的分类,(1)应用软件 应用软件是专门为某一应用目的而编制的软件,较常见的有以下几种:文字处理软件 用于输入、存贮、修改、编辑、打印文字材料等,例如WORD、WPS等;信息管理软件 用于输入、存贮、修改、检索各种信息;辅助设计软件用于高效地绘制、修改工程图纸,进行设计中的常规算,帮助人寻求好设计方案;实时控制软件用于随时搜集生产装置、飞行器等的运行状态信息,以此为依据按预定的方案实施自动或半自动控制,安全、准确地完成任务。,1.1.2 软件的分类,(2)系统软件 代表性的系统软件有:操作系统管理计算机的硬件设备,使应用软件能方便、高效地使用这些设备。在微机上常见的有:DOS、WINDOWS、UNIX、OS/2等;数据库管理系统有组织地、动态地存贮大量数据,使人们能方便、高效地使用这些数据。现在比较流行的数据库有FoxPro、DB-2、Access、SQL-server等;编译软件CPU执行每一条指令都只完成一项十分简单的操作,一个系统软件或应用软件,要由成千上万甚至上亿条指令组合而成。,1.1.2 软件的分类,2.按软件规模进行划分:根据所完成任务的不同以及开发任务、投入资金等因素,软件也可以按照规模来划分。(1)微型软件:这类软件一般只需要一个人几天即可完成,软件只有几K到几十K大小。由于规模很小,软件测试也极为容易;,1.1.2 软件的分类,(2)小型软件:这类软件一般由十人以内在半年内完成,开发前需要进行完整的开发设计。软件一般有几百K到十几M。完成时需要进行软件测试工作,但测试工作相对比较容易;(3)中型软件:中型软件一般由十几个人甚至几十个人开发,开发工作比较复杂,时限为半年至一年。软件大小一般有几十M。对于这种规模的软件软件测试十分必要。要进行严格的可行性分析,开发设计等工作;,1.1.2 软件的分类,(4)大型软件:这类软件一般由几十人开发,开发工作十分复杂,时限为1年甚至两年以上。软件大小上百M甚至几百M。这类软件开发前要进行详细可行性分析、需求分析、开发设计等工作,软件测试要贯彻在开发全过程。这类软件交付使用后往往还要进行一次甚至多次维护升级工作;(5)超大型软件:这类软件开发人员一般超过百人甚至几百人开发,开发工作十分艰辛,开发时限一般在2年以上,这类软件小则几百M,大则甚至几G。,1.1.2 软件的分类,3.按软件工作方式划分:(1)实时处理软件:指在事件或数据产生时,立即予以处理,并及时反馈信号,控制需要监测和控制的过程的软件。主要包括数据采集,分析,输出三部分;(2)分时软件:允许多个联机用户同时使用计算机;(3)交互式软件:能实现人机通信的软件;(4)批处理软件:把一组输入作业或一批数据以成批处理的方式一次运行,按顺序逐个处理完的软件。,1.1.2 软件的分类,4.按软件服务对象的范围划分:(1)项目软件:也称定制软件,是受某个特定客户(或少数客户)的委托,由一个或多个软件开发机构在合同的约束下开发出来的软件。例如军用防空指挥系统、卫星控制系统;(2)产品软件:是由软件开发机构开发出来直接提供给市场,或是为千百个用户服务的软件。例如,文字处理软件、文本处理软件、财务处理软件、人事管理软件等,1.1.3 软件工程的历史及发展,软件工程(Software Engineering,简称为SE)是针对软件这一具有特殊性质的产品的工程化方法。软件工程涵盖了软件生存周期的所有阶段,并提供了一整套工程化的方法,来指导软件人员的工作。,1.1.3 软件工程的历史及发展,1.软件工程的含义“软件工程”是科学和数学的某种应用,通过这一应用,使计算机设备的能力借助于计算机程序、过程和有关文档成为对人类有用的东西。软件工程的成果是为软件设计和开发人员提供思想方法和工具,而软件开发是一项需要良好组织,严密管理且各方面人员配合协作的复杂工作,软件工程正是指导这项工作的一门科学。,1.1.3 软件工程的历史及发展,软件工程应该包括哪些知识?IEEE在软件工程知识体系指南(SEWBOK:Guide to the Software Engineering Body of Knowledge 2004Version)中这样定义:软件开发、实施、维护的系统化、规范化、质量化的方法的应用,也就是软件的应用工程;对上述方法的研究。,1.1.3 软件工程的历史及发展,2.软件开发的三个历史阶段:第一个阶段是二十世纪50年代到60年代,是程序设计阶段,基本是个体手工劳动的生产方式。第二阶段是二十世纪60年代到70年代,是软件设计阶段,小组合作生产方式。第三个阶段是从二十世纪八十年代止今,为软件工程时代,是工程化的生产方式。,1.1.3 软件工程的历史及发展,3.软件危机 早期出现的软件危机主要表现在:(1)软件开发费用和进度失控。费用超支、进度拖延的情况屡屡发生。(2)软件的可靠性差。尽管耗费了大量的人力物力,而系统的正确性却越来越难以保证,出错率大大增加,由于软件错误而造成的损失十分惊人;(3)生产出来的软件难以维护。很多程序缺乏相应的文档资料,程序中的错误难以定位,难以改正,有时改正了已有的错误又引入新的错误。,1.1.3 软件工程的历史及发展,进入80年代以来,尽管软件工程研究与实践取得了可喜的成就,软件技术水平有了长足的进展,但是软件生产水平依然远远落后于硬件生产水平的发展速度。危机不仅没有消失,还有加剧之势。主要表现在:(1)软件成本在计算机系统总成本中所占的比例居高不下,且逐年上升。(2)软件开发生产率提高的速度远远跟不上计算机应用迅速普及深入的需要,软件产品供不应求的状况使得人类不能充分利用现代计算机硬件所能提供的巨大潜力。,1.1.3 软件工程的历史及发展,IBM360操作系统的历史教训已成为软件开发项目中的典型事例被记入历史史册。出现这种现象的主要原因是:(1)用户需求不明确。软件开发过程中,用户需求不明确问题主要体现在四个方面:在软件开发出来之前,用户自己也不清楚软件开发的具体需求;用户对软件开发需求的描述不精确,可能有遗漏、有二义性、甚至有错误;在软件开发过程中,用户还提出修改软件开发功能、界面、支撑环境等方面的要求;软件开发人员对用户需求的理解与用户本来愿望有差异。,1.1.3 软件工程的历史及发展,(2)缺乏正确的理论指导。缺乏有力的方法学和工具方面的支持。由于软件开发不同于大多数其他工业产品,其开发过程是复杂的逻辑思维过程,其产品极大程度地依赖于开发人员高度的智力投入。(3)软件开发规模越来越大。随着软件开发应用范围的增广,软件开发规模愈来愈大。大型软件开发项目需要组织一定的人力共同完成,而多数管理人员缺乏开发大型软件开发系统的经验,而多数软件开发人员又缺乏管理方面的经验。(4)软件开发复杂度越来越高。软件开发不仅仅是在规模上快速地发展扩大,而且其复杂性也急剧地增加.,1.2.1 软件生存周期及各阶段的工作 1.2.2 软件生存周期各阶段的文档编制,1.2 软件的生存周期,1.2.1 软件生存周期及各阶段的工作,软件生存周期的各个阶段的划分并没有一成不变的法则,不同的开发方式、软件种类、软件规模和开发环境都会在不同程度上影响软件生存周期各阶段的划分,但无论最终把生存周期如何根据自己的实际情况进行划分,都是旨在更好的利用手中的资源(主要指人力资源、软件资源、技术资源和源码资源),降低软件的开发风险、复杂度和开发成本(主要以开发的时间和投入资源为衡量标准),要做到最好的对软件生存周期各阶段进行划分,就必须遵循一条基本的原则,那就是在各阶段的任务应尽可能的相对独立,同一阶段各项任务的性质应尽可能的相同,从而达到降低每个阶段任务的复杂度,减少不同阶段任务之间的联系。这样作对软件项目开发的组织管理是十分有必要的,同时对最终的软件项目开发成功是不可或缺的。,既然软件开发周期这么重要,我们想要软件项目最终开发取得成功或是对软件进行管理和资源投入,我们就应当充份的了解周期里各个活动的定义和任务,才能合理,准确,客观的安排每一阶段的工作,以下就对各种活动的定义和任务做一下简单介绍,使之对它们有一个初步的了解。,1.2.1 软件生存周期及各阶段的工作,1.2.1 软件生存周期及各阶段的工作,1.可行性分析和项目开发计划 这两个活动通常被整合在一起进行,在实际工作中通常把它们归类到同一个阶段中。在这个阶段中经验起到了决定性的作用,接下来的任务就是制定详细的项目开发计划,项目开发计划主要根据所开发的项目的目标、性能、功能、规模来确定所需的资源,主要包括三个方面,即硬件资源、软件资源和人力资源,除此之外还有对项目的开发费用,开发进度做出估计,可供决策者和用户参考。至此,本阶段的工作任务已基本完成,这时候系统分析员应将可行性报告和项目开发计划一并提交管理部门审查。,1.2.1 软件生存周期及各阶段的工作,2.需求分析 需求分析的难点主要体现在以下几个方面:(1)问题的复杂性;(2)交流障碍;(3)用户对问题的陈述不完备性和不一致性;(4)需求易变性。,1.2.1 软件生存周期及各阶段的工作,针对需求分析人们提出了许多解决方法和自动化分析工具,如结构化分析方法和面向对象分析方法,CASE技术等等。解决问题的方法有许多,但都要遵循一些基本的原则:(1)可以把一个复杂问题按照某种分解方式进行分解并可逐层细化;(2)必须能够表达和理解问题的数据域和功能域;(3)必须具有良好的模型建立能力,能够准确的把问题用“图表”的形式表达出来。,1.2.1 软件生存周期及各阶段的工作,其实最终的目标就是为了用户的需要,回答这个系统要“做什么”的问题。具体如下:(1)问题识别 功能需求 性能需求 环境需求 用户界面需求(2)分析与综合,导出软件的逻辑模型(3)编写文档,1.2.1 软件生存周期及各阶段的工作,3.概要设计 概要设计的基本任务如下:(1)设计软件系统的逻辑结构。(2)设计软件所需要的数据库系统(3)编写概要设计文档(4)评审 软件概要设计的几个基本原理:(1)抽象(2)信息隐蔽(3)模块化,1.2.1 软件生存周期及各阶段的工作,4.详细设计 程序员会根据这些过程描述来编写程序代码,具体如下:(1)为每个模块进行详细的算法设计。这是需要用相应的工具来完成的,因为自然语言通常很容易具有“二义性”,而工具能做到含义唯一性;(2)为模块内的数据结构进行设计;(3)对数据库进行物理设计。注意这不是实现数据库,而是设计出数据库的具体物理结构;(4)其它设计(前期特殊代码设计、I/O格式设计、界面友好设计等);(5)编写详细设计说明书;(6)评审。,1.2.1 软件生存周期及各阶段的工作,5.编写代码 6.软件测试 7.软件实施8.软件维护 软件的维护一般的流程如下:(1)确定维护的类型;(2)对校正性维护要从评价错误的严重性开始;(3)对适应性维护和完善性维护可以视业务繁忙情况而定,也有条件制定比较完善的维护计划;(4)实施维护工作,要确保维护是必要和安全的;(5)维护回顾,看看有没有什么地方做的不对或遗漏的;(6)编写详细的维护日志。,1.2.2 软件生存周期各阶段的文档编制,软件生存周期各阶段交付文档如表1-1所示:1.可行性研究报告 8.用户手册2.项目开发计划 9.操作手册3.软件需求说明书 10.模块开发卷宗4.数据要求说明书 11.测试计划5.总体设计说明书 12.测试分析报告6.详细设计说明书 13.开发进度月报7.数据库设计说明书 14.项目开发总结报告,表1-1 软件生存周期各阶段交付文档【说明】:表1-1中前14类文档是国家标准软件产品开发文件编制指南所建议的。,1.3 软件开发常用模型,1.3.1 瀑布模型 1.3.2 增量模型 1.3.3 螺旋模型 1.3.4 变换模型 1.3.5 喷泉模型 1.3.6 智能模型 1.3.7 WINWIN模型 1.3.8 原型实现模型 1.3.9 RAD模型 1.3.10 并发开发模型 1.3.11 软件开发常用模型小结,1.3.1 瀑布模型,采用瀑布模型的软件过程如图1-2所示。,图1-2 软件生存周期的瀑布模型,1.3.2 增量模型,采用增量模型的软件过程如图1-3所示。,图1-3 采用增量模型的软件过程,1.3.3 螺旋模型,图1-4 螺旋模型,螺旋模型沿着螺线旋转,如图1-4所示,1.3.3 螺旋模型,采用螺旋模型的软件过程如图1-5所示,图1-5 采用螺旋模型的软件过程,1.3.4 变换模型,采用变换模型的软件过程如图1-6所示,图1-6 采用变换模型的软件过程,1.3.5 喷泉模型,采用喷泉模型的软件过程如图1-7所示,图1-7 采用喷泉模型的软件过程,1.3.6 智能模型,采用智能模型的软件过程如图1-8所示,图1-8 采用智能模型的软件过程,1.3.7 WINWIN模型,采用WINWIN模型的软件过程如图1-9所示,图1-9 采用WINWIN模型的软件过程,1.3.8 原型实现模型,采用原型实现模型的软件过程如图1-10所示,图1-10 采用原型实现模型的软件过程,1.3.9 RAD模型,采用RAD模型的软件过程如图1-11所示,图1-11 采用RAD模型的软件过程,1.3.10 并发开发模型,采用并发开发模型的软件过程中一个活动的示意如图1-12所示,图1-12 并发过程模型的一个活动,1.3.11 软件开发常用模型小结,软件过程模型发展经历了以下阶段:以软件需求完全确定为前提的第1代软件过程模型,如瀑布模型等。在开始阶段只能提供基本需求的渐进式开发模型,如螺旋模型和原型实现模型等。以体系结构为基础的基于构件组装的开发模型,如基于构件的开发模型和基于体系结构的开发模型等。,1.4 软件开发方法和软件开发工具,1.4.1 软件开发环境1.4.2 软件开发方法综述1.4.3 软件开发工具,1.4.1 软件开发环境,软件开发环境(Software Development Environment)是指在基本硬件和软件的基础上,为支持系统软件和应用软件的工程化开发和维护而使用的一组软件,简称SDE。它由软件工具和环境集成机制构成,前者用以支持软件开发的相关过程、活动和任务,后者为工具集成和软件的开发、维护及管理提供统一的支持。,1.4.1 软件开发环境,1.软件开发环境可按以下几种角度分类:(1)按软件开发模型及开发方法分类,有支持瀑布模型、演化模型、螺旋模型、喷泉模型以及结构化方法、信息模型方法、面向对象方法等不同模型及方法的软件开发环境。(2)按功能及结构特点分类,有单体型、协同型、分散型和并发型等多种类型的软件开发环境。(3)按应用范围分类,有通用型和专用型软件开发环境。,1.4.1 软件开发环境,2.对于软件开发方法的一般要求包括:(1)覆盖开发全过程,并且便于在各阶段间的过渡;(2)便于在开发各阶段中有关人员之间的通信;(3)支持有效的解决问题的技术;(4)支持系统设计和开发的各种不同途径;(5)在开发过程中支持软件正确性的校验和验证;(6)便于在系统需求中列入设计、实际和性能的约束;(7)支持设计师和其他技术人员的智力劳动;(8)在系统的整个生存周期都支持它的演化;(9)受自动化工具的支持。,1.4.2 软件开发方法综述,下面介绍几种流行的开发方法:1.结构化方法2.面向数据结构的软件开发方法3.面向问题的分析法4.原型化方法5.面向对象的软件开发方法6.可视化开发方法,1.4.3 软件开发工具,目前有很最多种正在使用的软件开发工具,大致分为以下几种:1.项目管理工具 2.项目需求管理工具 3.软件开发管理工具 4.代码开发工具,小 结,计算机软件:是指计算机程序以及解释和指导使用程序的文档的总和。软件的分类:软件工程(Software Engineering,简称为SE):针对软件这一具有特殊性质的产品的工程化方法。软件生存周期:以需求为触发点,提出软件开发计划的那一刻开始直到软件在实际应用中完全报废为止的一个完整的周期。软件生存周期各个阶段:可行性分析和项目开发计划、需求分析、概要设计、详细设计、编写代码、软件测试和软件维护等活动。软件开发的常用模型:瀑布模型、增量模型、螺旋模型、变换模型、喷泉模型、智能模型、WINWIN模型、原形实现模型、RAD模型、并发开发模型软件开发环境(Software Development Environment):在基本硬件和软件的基础上,为支持系统软件和应用软件的工程化开发和维护而使用的一组软件,简称SDE。常用软件开发工具,习 题,1.什么是计算机软件?2.软件如何分类?3.什么是软件工程?4.什么是软件生存周期?5.软件生存周期各个阶段是什么?6.软件开发的常用模型有那几种?7.什么是软件开发环境?8.常用软件开发工具有几种?9.简述软件开发的历史。,课后实训题,实训活动1:软件开发历史不同阶段的分析【实训目标】了解软件开发不同历史阶段的特征。【能力培养】做集中的积极动员;安排课余时间收集资料完成课题;用各种直观的方式表达信息。【实训任务】在不同的历史阶段,软件开发表现出不同的技术特征与开发特点。比较各个软件开发时期,了解其特征与局限。不局限于书本的内容,利用课余时间用多种方式查找资料,集思广益。,课后实训题,【实训要求】以个人为单位进行分析,并完成表1-2;分组讨论。,表1-2 软件开发各个历史阶段的特征及分析,课后实训题,实训活动2:软件开发方法调查研究【实训目标】了解常用软件开发方法及其特点【能力培养】安排自己的任务;准重他人意见;锻炼团队合作能力;用各种直观方式表达信息。,课后实训题,【实训任务】查找资料(网上、图书馆等方式),了解各种软件开发方法及其特点和局限性。【实训要求】将全班划分为若干组,每组4-7人为宜,指派或组内选出一名组长;组长在组内进行人员分工;调查研究之后组间进行交流;完成调查报告,根据调查研究情况列出不同开发方法的简介、特点及局限性等。,