软件工程讲义-陆丽娜自考_第1页
软件工程讲义-陆丽娜自考_第2页
软件工程讲义-陆丽娜自考_第3页
软件工程讲义-陆丽娜自考_第4页
软件工程讲义-陆丽娜自考_第5页
已阅读5页,还剩189页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、课程介绍我们现在看到的这个软件工程多媒体的网络课件,是遵照全国高等教育自学考试委员会电子电工与信息类专业委员会审定的软件工程自学考试大纲要求而设计的。自考的学生们经过了基础课和专业基础的学习,进入了专业课程的阶段,软件工程作为一门实践性很强的专业课,对于缺乏编程经验的学生来说,在学习中会遇到一定的困难,为了帮助自学考试考生学好软件工程,我们总结教学实践经验,收集整理有关的自考指导用书,按照大纲和题型要求制作了这个网络课件,力求把枯燥深奥的理论知识,通过具体的实例来剖析,帮助学生理解,同时加入了模拟试卷的内容,力争能为同学们通过考试提供练习的机会。 网络课件以考试大纲为主线,以陆丽娜主编、经济科

2、学出版社出版的教材为根本。其内容分为:课程学习、仿真试题、实验指导、模拟试卷等八个栏目。课程学习 HYPERLINK /course_ware/software/class_content.htm l # 第1章 绪论1.1 软件工程的产生 软件的特点“软件”一词是20世纪60年代才出现的,它是指:计算机程序及其说明程序的各种文档。软件与硬件一起构成完整的计算机系统,它们是相互依存,缺一不可的。软件是一种特殊的产品,它具有以下独特的特性。(1)软件是一种逻辑产品,它与物质产品有很大的区别。软件产品是看不见摸不着的,因而具有无形性,它是脑力劳动的结晶,它以程序和文档的形式出现,保存在计算机存储器

3、和光盘介质上,通过计算机的执行才能体现它的功能和作用。(2)软件产品的生产主要是研制,软件产品的成本主要体现在软件的开发和研制上,软件开发研制完成后,通过复制就产生了大量软件产品。(3)软件产品不存在磨损、消耗问题。(4)软件产品生产的成本主要是脑力劳动,还未完全摆脱手工开发方式,大部分产品是“定做”的。(5)软件费用不断增加,软件成本相当昂贵。软件的研制工作需要投入大量的、复杂的、高强度的脑力劳动,它的成本非常高。1.1.2 软件生产的发展自从第一台计算机诞生以后,就开始了软件的生产,到现在为止,经过了三个阶段。即程序设计时代,程序系统时代,软件工程时代。1.程序设计时代(1964年1956

4、年)这个阶段的生产方式是个体手工劳动,使用的工具是机器语言,汇编语言。2.程序系统时代(1956年1968年)这阶段的生产方式是作坊的小集团合作生产,生产工具是高级语言,开发方法仍旧靠个人技巧,但开始提出结构化方法。3.软件工程时代(1968年至现在)这阶段的生产方式是工程化的生产,使用数据库、开发工具、开发环境、网络、分布式、面向对象技术来开发软件。1.1.3软件危机 软件危机产生的原因:(1)软件的规模越来越大,结构越来越复杂。(2)软件开发管理困难而复杂。(3)软件开发费用不断增加。(4)软件开发技术落后。(5)生产方式落后。(6)开发工具落后,生产提高缓慢。1.1.4软件工程1.软件工

5、程定义软件工程有多种定义,其中一种是:用科学知识和技术原理来定义、开发、维护软件的一门学科。2.软件工程性质软件工程是一门综合性的交叉学科,它涉及计算机科学、工程科学、管理科学、数学等领域。3.软件工程目标(1)付出较低的开发成本;(2)达到要求的软件功能;(3)取得较好的软件性能;(4)开发的软件易于移植;(5)需要较低的维护费用;(6)能按时完成开发任务,及时交付使用;(7)开发的软件可靠性高。4.软件工程内容软件工程研究的主要内容是软件开发技术和软件管理两方面。在软件开发技术中,主要研究软件开发方法、软件开发过程、软件开发工具和环境。在软件开发管理中,主要是研究软件管理学、软件经济学、软

6、件心理学等。5.软件工程面临的问题(1)软件费用(2)软件可靠性(3)软件维护(4)软件生产率(5)软件重用1.2软件工程和软件生存周期软件工程过程软件工程过程包含如下七个过程(1)获取过程。(2)供应过程。(3)开发过程。(4)操作过程。(5)维护过程。(6)管理过程。(7)支持过程。1.2.2 软件生存周期 软件生存周期是指一个软件从提出开发要求开始直到该软件报废为止的整个时期。 通常,软件生存周期包括可行性分析和项目开发计划、需求分析、概要设计、详细设计、编码、测试、维护等活动,可以将这些活动以适当方式分配到不同阶段去完成。1.可行性分析和项目开发计划 明确“要解决的问题是什么?”,“解

7、决的问题的办法和费用”,“解决的问题所需的资源和时间”。要回答这些问题,就要进行问题定义、可行性分析,制定项目开发计划。2.需求分析 需求分析阶段的任务是准确地确定软件系统必须做什么,确定软件系统具备哪些功能。写出软件需求规格说明书。3.概要设计 概要设计的任务是把软件需求规格说明书中确定的各项功能转换成需要的体系结构。4.详细设计 详细设计阶段就是为每个模块完成的功能进行具体描述,要把功能描述转变为精确的、结构化的过程描述。5.编码 编码阶段就是把每个模块的控制结构转换成计算机可接受的程序代码。6.测试 测试是保证软件质量的重要手段,其主要方式是在设计测试用例的基础上检验软件的各个组成部分。

8、测试分为单元测试、集成测试、确认测试。7.维护软件维护是软件生存周期中时间最长的阶段。已交付的软件投入正式使用后,便进入软件维护阶段,它可以持续几年甚至几十年。1.3 软件生存周期模型,方法和工具 软件生存周期模型 软件生存周期模型是描述软件开发过程中各种活动如何执行的模型。 目前有若干种软件生存周期模型。例如:瀑布模型、增量模型、螺旋模型、喷泉模型、变换模型和基于知识的模型。1.瀑布模型 瀑布模型是将软件生存周期各个活动规定为自上向下,按照线性顺序连接的若干阶段的模型。该模型支持结构化的设计方法,但它是一种理想的线性开发模式,缺乏灵活性,无法解决软件需求不明确或不准确的问题。2.增量模型 增

9、量模型是一种非整体开发的模型。软件在该模型中是“逐渐”开发出来的。该模型有较大的灵活性,适合于软件需求不明确、设计方案有一定风险的软件项目。3.螺旋模型 螺旋模型是一种风险驱动的模型。螺旋模型适合于大型软件的开发,它吸收了软件工程“演化”的概念,包括需求定义、风险分析、工程实现及用户评估四个阶段,螺旋模型由上述四个阶段组成的迭代模型,迭代的结果必须尽快收敛到客户允许的或可接受的目标范围内。4.喷泉模型 喷泉模型是一种以用户需求为动力,以对象作为驱动的模型,适合于面向对象的开发方法。5.基于知识的模型 基于知识的模型又称智能模型,它把瀑布模型和专家系统结合在一起。该模型在开发的各个阶段都利用相应

10、的专家系统来帮助软件人员完成开发工作,使维护在系统需求说明阶段开始。该模型还处于研究实验阶段,还未达到实用阶段。6.变换模型 这是一种适合于形式化开发方法的模型。从软件需求形式化说明开始,经过一系列变换,最终得到系统的目标程序。 软件开发方法 软件开发方法是一种使用早已定义好的技术集及符号表示习惯来组织软件生产的过程。软件开发的目标是在规定的投资和时间内,开发出符合用户需求的高质量的软件。为了达到此目的,需要成功的开发方法。下面介绍几种常用的软件开发方法。1.结构化方法 结构化方法由结构化分析、结构化设计、结构化程序设计构成。它是一种面向数据流的开发方法。该方法采用自顶向下、逐步求精的指导思想

11、,应用较广,技术成熟。 结构化分析是根据分解与抽象的原则,按照系统中数据处理的流程,用数据流图来建立系统的功能模型,从而完成需求分析工作。 结构化设计是根据模块独立性准则、软件结构准则将数据流图转换为软件的体系结构,用软件结构图来建立系统的物理模型,实现系统的概要设计。 结构程序设计是根据结构程序设计原理,将每个模块的功能用相应的标准控制结构表示出来,从面实现详细设计。 结构化方法不适应规模大的项目,对于特别复杂的项目,该方法难于解决软件重用问题,难于适应需求变化的问题,难于彻底解决维护问题。2.Jackson方法 这是一种面向数据结构的开发方法。JSP方法是以数据结构为驱动的,适合于小规模的

12、项目。3.维也纳开发方法(VDM) 这是一种形式化的开发方法,软件的需求用严格的形式语言描述,然后把描述模型逐步变换成目标系统。4.面向对象的开发方法 面向对象的开发方法完全不同于传统开发方法,它是90年代的主流开发方法。 面向对象开发方法包括面向对象分析、面向对象设计、面向对象实现。面向对象开发方法有Booch方法、Coad方法和OMT方法等。为了统一各种面向对象方法的术语、概念和模型,1997年推出了统一建模语言,即UML(Unified Modeling Language)语言。它是面向对象的标准建模语言,通过统一的语义和符号表示,使各种方法的建模过程和表示统一起来,将成为面向对象建模的

13、工业标准。 软件开发工具1. 软件工具的重要性 软件工具一般使指为了支持软件人员开发和维护活动而使用的软件。2.工具箱 最初的软件工具是以工具箱的形式出现的,一种工具支持一种开发活动,然后将各种工具简单具有结合起来就构成工具箱。3.软件开发环境 由于工具箱存在的问题,人们在工具系统的整体化及集成化方面开展一系列研究工作,使之形成完整的软件环境。4.计算机辅助软件工程 计算机辅助软件工程可以简单地定义为软件开发地自动化,通常简称为CASE(Computer Aided Software Engineering)。第1章例题分析与解答/course_ware/software/test/show.

14、asp?filename=1.txt&fname=第1章#一、填空题1.软件与物质产品有很大的区别,软件是一种_产品。 HYPERLINK /course_ware/software/test/show.asp?filename=1.txt&fname=第1章 l # 答案2.软件工程是一门综合性交叉学科,计算机科学着重于理论和原理,软件工程着重于_。 HYPERLINK /course_ware/software/test/show.asp?filename=1.txt&fname=第1章 l # 答案3.概要设计主要是把各项功能需求转换成系统的_。 HYPERLINK /course_wa

15、re/software/test/show.asp?filename=1.txt&fname=第1章 l # 答案4.最基本、应用广泛、以文档为驱动、适用于开发功能明确的软件项目生存期模型是_。 HYPERLINK /course_ware/software/test/show.asp?filename=1.txt&fname=第1章 l # 答案5.简单实用、应用广泛、技术成熟的开发方法是_。 HYPERLINK /course_ware/software/test/show.asp?filename=1.txt&fname=第1章 l # 答案二、选择题1.同一软件的大量软件产品的生产主要

16、是通过( )而得到。A.研究 B.复制 C.开发 D.研制 HYPERLINK /course_ware/software/test/show.asp?filename=1.txt&fname=第1章 l # 答案2.作坊式小团体合作生产方式的时代是( )时代。A.程序设计 B.软件生产自动化 C.程序系统 D.软件工程 HYPERLINK /course_ware/software/test/show.asp?filename=1.txt&fname=第1章 l # 答案3.软件工程与计算机科学性质不同,软件工程着重于( )。A.理论研究 B.原理探讨 C.建造软件系统 D.原理的理论 HY

17、PERLINK /course_ware/software/test/show.asp?filename=1.txt&fname=第1章 l # 答案4.将每个模块的控制结构转换成计算机可接受的程序代码是( )阶段的任务。A.编码 B.需求分析 C.详细设计 D.测试 HYPERLINK /course_ware/software/test/show.asp?filename=1.txt&fname=第1章 l # 答案5.软件生存周期中时间最长的是( )阶段。A.需求分析 B.概要设计 C.测试 D.维护 HYPERLINK /course_ware/software/test/show.a

18、sp?filename=1.txt&fname=第1章 l # 答案第1章自测题及参考答案一、名称解释1.软件 2.文档 3.软件工程4.软件生存周期 5.软件工程过程 6.软件生存周期模型7.软件开发方法 8.软件工具二、填空题1.构成一个完整计算机系统的两部分是硬件与_。2.程序设计时代的生产方式是_。3.软件工程涉及到几个学科,它是一门_学科。4.软件开发划分的各阶段任务尽可能独立,同一阶段任务性质尽可能_。5.将软件生存周期各个活动规定为依线性顺序联接的若干阶段的模型是_模型。6.喷泉模型是一种以用户需求为动力,以_为驱动的模型。7.结构化方法是一种面向数据流的开发方法。由结构化分析、

19、_、结构化程序设计构成。8.软件工程研究的主要内容是软件开发管理和_两个方面。9.软件工具是支持软件开发人员的开发和维护活动而使用的_。10.一个软件项目的开发中,要采用一种生存周期模型,要按照某种_,使用相应的工具来进行。三、选择题1.软件是一种( )产品。A.物质 B.逻辑 C.有形 D.消耗2.软件产品的开发主要是( )。A.复制 B.再生产 C.拷贝 D.研制3.个体手工劳动生产方式的时代是( )。A.程序设计 B.软件生产自动化 C.程序系统 D.软件工程4.与计算机科学的理论研究不同,软件工程是一门( )学科。A.理论性 B.原理性 C.工程性 D.心理性5.软件重用的单位是( )

20、。A.软件模块 B.性能 C.系统 D.功能6.软件开发费用只占整个软件系统费用的( )。A.1/2 B.1/3 C.1/4 D.2/37.软件开发中大约要付出( )的工作量进行测试和排错。A.20 B.30 C.40 D.508.准确地解决“软件系统必须做什么”是( )阶段的任务。A.可行性研究 B.需求分析 C.详细设计 D.编码9.软件生存周期中最长的是( )阶段。A.需求分析 B.概要设计 C.测试 D.维护 四、简答题1.软件产品的特性是什么?2.软件生产有几个阶段?各有何特征?3.什么是软件危机?产生的原因是什么?4.软件工程的性质、目标和内容是什么?5.软件工程面临的问题是什么?

21、6.软件工程过程有哪些过程?7.软件生存周期有哪几个阶段?8.软件生存周期模型有哪些主要模型?9.有哪些主要软件开发方法?参考答案二填空题1.软件 2.个体手工劳动 3.综合性交叉 4.相同 5.瀑布 6.对象 7.结构化设计 8.软件开发技术 9.软件 10.开发方法三、选择题1.B 2.D 3.A 4.C 5.A 6.B 7.C 8.B 9.D HYPERLINK /course_ware/software/class_content.htm l # 第2章 软件可行性研究2.1可行性研究在进行任何一项较大的工程时,首先都要进行可行性分析和研究。目的就是用最小的代价在尽可能短的时间内确定该

22、软件项目是否能够开发,是否值得去开发。可行性研究的任务1.技术可行性对要开发的项目的功能、性能、限制条件进行分析,确定在现有的资源条件下,技术风险有多大,项目是否能实现。技术可行性是最难解决的,它一般要包括:(1)开发的风险:在给出的限制范围内,能否设计出系统并实现必须的功能和性能。(2)资源的有效性:人力资源以及用于建立系统的其他资源是否具备。(3)技术:目前的技术水平能否支持这个系统。(4)开发人员在评估技术可行性时,一旦估计错误,将会出现灾难性后果。2.经济可行性进行开发成本的估算以及了解取得效益的评估,确定要开发的项目是否值得投资开发。3.社会可行性要开发的项目是否存在任何侵犯、妨碍等

23、责任问题,要开发项目的运行方式在用户组织内是否行得通,现有管理制度、人员素质、操作方式是否可行。2.1.2 可行性研究的具体步骤典型性的可行性研究有下列步骤:1.确定项目规模和目标分析员对有关人员进行调查访问,仔细阅读和分析有关的材料,对项目的规模和目标进行定义和确认,清晰地描述项目的一切限制和约束,确保分析员正在解决的问题确实是要解决的问题。 2.研究正在运行的系统收集、研究、分析现有系统的文档资料,实地考察现有系统,在考察的基础上,访问有关人员,然后描述现有系统的高层系统流程图,与有关人员一起审查该系统流程图是否正确。这个系统流程图反映了现有系统的基本功能和处理流程。3.建立新系统的高层逻

24、辑模型根据对现有系统的分析研究,逐步明确了新系统的功能、处理流程以及所受的约束,然后使用建立逻辑模型的工具数据流图和数据字典来描述数据在系统中的流动和处理情况。现在还不是软件需求分析阶段,不是完整、详细地描述,只是概括地描述高层的数据处理和流动。4.导出和评价各种方案分析员建立了新系统的高层逻辑模型之后,要从技术角度出发,提出实现高层逻辑模型的不同方案,即导出若干较高层次的物理解法。根据技术可靠性、经济可行性、社会可行性对各种方案进行评估,去掉行不通的解法,就得到了可行的解法。5.推荐可行的方案根据上述可行性研究的结果,应该决定该项目是否值得去开发。若值得开发,那么可行的解决方案是什么,并且说

25、明该方案可行的原因和理由。要求分析员对推荐的可行方案进行成本效益分析。6.编写可行性研究报告将上述可行性研究过程的结果写成相应的文档,即可行性研究报告,提醒用户和使用部门仔细审查,从而决定该项目是否进行开发,是否接受可行的实现方案。2.2 系统流程图1.系统流程图的作用系统流程图是描绘物理系统的传统工具,它用图形符号来表示系统中的各个元素,例如人工处理、数据处理、数据库、文件、设备等。它表达了系统中各个元素之间的信息流动的情况。2.系统流程图的符号系统流程图的符号如表2-1所示。表2-1 符号名称说明处理能改变数据值或数据位置的加工或部件,例如,程序模块、处理机等都是处理。输入/输出指出输入或

26、输出(或既输入又输出),是一个广义的不指明具体设备的符号连接指出转到图的另一部分或从图的另一部分转来,通常在同一页上。换页连接指出转到另一页或由另一页图转来。数据流用来连接其他符号,指明数据流动方向。文档通常表示打印输出,也可表示用打印终端输入数据联机存储表示任何种类的联机存储,包括磁盘、软盘和海量存储器件等磁盘磁盘输入/输出,也可表示存储在磁盘上的文件或数据库显示CRT终端或类似的显示部件,可用于输入或输出,也可既输入又输出。人工输入人工输入数据的脱机处理,例如,填写表格。人工操作人工完成的处理,例如,会计在工资支票上签名辅助操作使用设备进行的脱机工作通信链路通过远程通信线路或链路传送数据3

27、.系统流程图的例子 下面以某工厂的库房管理为例,说明系统流程图的使用。2.3成本效益分析成本效益分析的目的是从经济角度评价开发一个新的软件项目是否可行。成本效益分析首先是估算将要开发的系统的开发成本,然后与可能取得的效益进行比较和权衡。效益分有形效益和无形效益两种。有形效益可以用货币的时间价值、投资回收期、纯收入等指标进行度量;无形效益主要从性质上、心理上进行衡量,很难直接进行量的比较。下面主要介绍有形效益的分析:1.货币的时间价值项目开发后,应取得相应得效益,有多少效益才合算?这就要考虑货币的时间价值。通常用利率表示货币的时间价值。设年利率为i,现存入P元,n年后可得钱数为F,若不计复利则F

28、=P(1+ni)F就是P元在n年后得价值。反之,若n年能收入F元,那么这些钱现在得价值是:P =F/(1+ni)2.投资回收期通常用投资回收期衡量一个开发项目的价值。投资回收期就是使累计的经济效益等于最初的投资费用所需的时间。投资回收期越短,就越快获得利润,则该项目就越值得开发。3.纯收入衡量项目价值的另一个经济指标是项目的纯收入,也就是在整个生存周期之内的累计经济效益(折合成现在值)与投资之差。若某项目的纯收入小于零,则该项目是不值得投资的。第2章例题分析与解答/course_ware/software/test/show.asp?filename=2.txt&fname=第2章一、填空题1

29、.可行性研究实质上是进行一次简化、压缩了的_。 HYPERLINK /course_ware/software/test/show.asp?filename=2.txt&fname=第2章 l # 答案2.可行性研究的三个方面是技术可行性、社会可行性和_。 HYPERLINK /course_ware/software/test/show.asp?filename=2.txt&fname=第2章 l # 答案3.可行性研究的第一个具体步骤是_。 HYPERLINK /course_ware/software/test/show.asp?filename=2.txt&fname=第2章 l #

30、答案4.若年利率为i,不计复利,P元在n年后的价值F是_。 HYPERLINK /course_ware/software/test/show.asp?filename=2.txt&fname=第2章 l # 答案5.可行性研究中描述系统高层物理模型的工具是_。 HYPERLINK /course_ware/software/test/show.asp?filename=2.txt&fname=第2章 l # 答案二、选择题1.可行性研究的目的是决定( )。A.开发项目 B.项目值得开发否 C.规划项目 D.维护项目 HYPERLINK /course_ware/software/test/s

31、how.asp?filename=2.txt&fname=第2章 l # 答案2.技术可行性要研究的问题之一是( )。A.存在侵权否 B.成本效益问题 C.运行方式可行否 D.技术风险问题 HYPERLINK /course_ware/software/test/show.asp?filename=2.txt&fname=第2章 l # 答案3.纯收入是累计效益现在值与投资之( )。A.和 B.差 C.积 D.商 HYPERLINK /course_ware/software/test/show.asp?filename=2.txt&fname=第2章 l # 答案4.项目开发计划这类文档是一

32、种( )。A.技术性文档 B.管理性文档 C.需求分析文档 D.设计文档 HYPERLINK /course_ware/software/test/show.asp?filename=2.txt&fname=第2章 l # 答案第2章自测题及参考答案一、名称解释1.可行性研究 2.技术可行性 3.经济可行性4.社会可行性 5.货币时间价值 6.投资回收期7.纯收入 8.系统流程图二、填空题1.可行性研究的目的是用最小的代价,在尽可能短的时间内,确定_。2.可行性研究在进行简要需求分析和设计时,要在高层次上以_进行。3.系统流程图用图形符号表示系统中各个元素,表达了系统中各个元素之间的_。4.软

33、件工程有两种效益,它们是无形效益和_。5.若年利率为i,不计复利,n年后能收入F元的现在价值P=_。6.纯收入是软件生存周期内两项值之差,这两项是_。7.项目开发计划是一种_文档。8.可行性研究具体步骤的最后一步是_。三、选择题1.研究硬软件资源的有效性是进行( )研究的一方面。A.技术可行性 B.经济可行性 C.社会可行性 D.操作可行性2.可行性研究要进行的需求分析和设计应是( )。A.详细的 B.全面的 C.简化、压缩的 D.彻底的3.可行性分析中,系统流程图用于描述( )。A.当前运行系统 B.当前逻辑模型 C.目标系统 D.新系统4.系统流程图是一种工具,它用于描述( )。A.逻辑系

34、统 B.程序系统 C.体系结构 D.物理系统5.年利率为i,现存入P元不计复利,n年后本金利息为( )。A.P(1+i)n B.P(1in) C.P(1+in) D.P(1+i)n四、简答题1.可行性研究的任务是什么?2.可行性研究有哪些步骤?3.可行性研究的目的。4.可行性研究报告的主要内容。5.怎样计算投资回收期和纯收入?6.项目开发计划有哪些主要内容。参考答案二、填空题1.项目值得开发否 2.较抽象形式 3.信息流动 4.有形效益 5.F/(1+ni)6.经济效益与投资 7.管理性 8.编写可行性报告。三、选择题1.A 2.C 3.A 4.D 5.C HYPERLINK /course_

35、ware/software/class_content.htm l # 第3章 软件需求分析3.1 需求分析的任务 需求分析的概念开发人员要准确理解用户的要求,进行细致的调查分析,将用户非形式的需求陈述转化为完整的需求定义,再由需求定义转化到相应的形式功能规约(需求规格说明)的过程。需求分析虽处于软件开发过程的初期阶段,但它对于整个软件开发过程以及软件产品质量是至关重要的。随着软件系统复杂性的提高及规模的扩大,需求分析在软件开发中的所处的地位愈加突出,从而也愈加困难。1.需求分析的难点(1)问题的复杂性。用户需求所涉及的因素很多,如系统功能和运行环境。(2)交流障碍。需求分析涉及人员较多,分别

36、具备不同的背景知识,处于不同的出发点,造成了相互之间交流的困难。(3)不完备性和不一致性。用户对问题的陈述往往是不完备的,其各方面的需求还可能存在着矛盾,需求分析要消除其矛盾,形成完备及一致的定义。(4)需求易变性。用户需求的变动往往会影响到需求分析,导致系统的不一致性和不完备性。2.需求分析的基本原则(1)必须能够表达和理解问题的数据域和功能域。数据域包括数据流、数据内容和数据结构,而功能域反映数据域三方面的控制信息。(2)可以把一个复杂问题按功能进行分解并可逐层细化。(3) 建模。建立模型可以帮助分析人员更好地理解软件系统的信息、功能、行为,这些模型也是软件设计的基础。3.1.2 需求分析

37、的基本任务1.问题识别(1) 功能需求:明确所开发的软件必须具备什么样的功能。(2) 性能需求:明确待开发的软件的技术性能指标。(3) 环境需求:明确软件运行时所需要的软、硬件的要求。(4) 用户界面需求:明确人机交互方式、输入输出数据格式。2. 分析与综合,导出软件的逻辑模型分析人员对获取的需求,进行一致性的分析检查,在分析、综合中逐步细化软件功能,划分成各个子功能。用图文结合的形式,建立起新系统的逻辑模型。3. 编写文档(1) 编写“需求规格说明书”,把双方共同的理解与分析结果用规范的方式描述出来,作为今后各项工作的基础。(2) 编写初步用户使用手册,着重反映被开发软件的用户功能界面和用户

38、使用的具体要求,用户手册能强制分析人员从用户使用的观点考虑软件。(3) 编写确认测试计划,作为今后确认和验收的依据。(4) 修改完善软件开发计划。在需求分析阶段对待开发的系统有了更进一步的了解,所以能更准确地估计开发成本、进度及资源要求,因此对原计划要进行适当修正。3.2 结构化分析方法结构化分析(Structured Analysis,简称SA),是面向数据流进行需求分析的方法。SA也是一种建模活动,该方法使用简单易读符号,根据软件内部数据传递、变换的关系,自顶向下逐层分解,描绘出满足功能要求的软件模型。 自顶向下逐层分解的分析策略面对一个复杂的问题,分析人员不可能一开始就考虑到问题的所有方

39、面以及全部细节,采用的策略往往是分解,把一个复杂的问题划分成若干小问题,然后再分别解决,将问题的复杂性降低到人可以掌握的程度。3.2.2 描述工具SA方法利用图形等半形式化的描述方式表达需求,简明易懂,用它们形成需求说明书中的主要部分。描述工具是:(1)数据流图:描述系统由哪几部分组成,各部分之间有什么联系等等。(2)数据字典:定义了数据流图中每一个图形元素。(3)描述加工逻辑的结构化语言、判定表、判定树:详细描述数据流图中不能被再分解的每一个加工。3.2.3 SA分析步骤SA方法利用图形等半形式化的描述方式表达需求,简明易懂,用它们形成需求说明书中的主要部分。描述工具是:(1)了解当前系统的

40、工作流程,获得当前系统的物理模型。通过对当前系统的详细调查,了解当前系统的工作过程,同时收集资料、文件、数据、报表等,将看到的、听到的、收集到的信息和情况用图形描述出来。也就是用一个模型来反映自己对当前系统的理解,如画系统流程图。(2)抽象出当前系统的逻辑模型。物理模型反映了系统“怎么做”的具体实现,去掉物理模型中非本质的因素,抽取出本质的因素,构造出当前系统的逻辑模型,反映了当前系统“做什么”的功能。(3)建立目标系统的逻辑模型。分析、比较目标系统与当前系统逻辑上的差别,明确目标系统到底要“做什么”,从而从当前系统的逻辑模型导出目标系统的逻辑模型。(4)作进一步补充和优化。为了对目标系统做完

41、整的描述,还需要对得到的逻辑模型做一些补充。3.3 数据流图(DFD)数据流图,简称DFD,是SA方法中用于表示系统逻辑模型的一种工具,它以图形的方式描绘数据在系统中流动和处理的过程,由于它只反映系统必须完成的逻辑功能,所以它是一种功能模型。下图是一个飞机机票预订系统的数据流图,它反映的功能是: 旅行社把预订机票的旅客信息 (姓名、年龄、单位、身份证号码、旅行时间、目的地等)输入机票预订系统。系统为旅客安排航班,打印出取票通知单(附有应交的账款)。旅客在飞机起飞的前一天凭取票通知单交款取票,系统检验无误,输出机票给旅客。 基本图形符号数据流图有四种基本图形符号: :箭头,表示数据流;:圆或椭圆

42、,表示加工;= :双杠,表示数据存储;:方框,表示数据的源点或终点。(1) 数据流。数据流是数据在系统内传播的路径,因此由一组成分固定的数据组成。如订票单由旅客姓名、年龄、单位、身份证号、日期、目的地等数据项组成。由于数据流是流动中的数据,所以必须有流向,除了与数据存储之间的数据流不用命名外,数据流应该用名词或名词短语命名。(2)加工(又称为数据处理)。对数据流进行某些操作或变换。每个加工也要有名字,通常是动词短语,简明地描述完成什么加工。在分层的数据流图中,加工还应编号。(3)数据存储(又称为文件),指暂时保存的数据,它可以是数据库文件或任何形式的数据组织。(4)数据源点或终点,是本软件系统

43、外部环境中的实体(包括人员、组织或其他软件系统),统称外部实体。一般只出现在数据流图的顶层图。3.3.2画数据流图的步骤(1)首先画系统的输入输出,即先画顶层数据流图。顶层流图只包含一个加工,用以表示被开发的系统,然后考虑该系统有哪些输入数据、输出数据流。顶层图的作用在于表明被开发系统的范围以及它和周围环境的数据交换关系。下图为飞机机票预订系统的顶层图。(2)画系统内部,即画下层数据流图。不再分解的加工称为基本加工。一般将层号从0开始编号,采用自顶向下,由外向内的原则。画0层数据流图时,分解顶层流图的系统为若干子系统,决定每个子系统间的数据接口和活动关系。例如,在上面的机票预订系统按功能可分成

44、两部分,一部分为旅行社预订机票,另一部分为旅客取票,两部分通过机票文件的数据存储联系起来,0层数据流图如图3-4。(3)注意事项。命名。不论数据流、数据存储还是加工,合适的命名使人们易于理解其含义。画数据流而不是控制流。数据流反映系统“做什么”,不反映“如何做”,因此箭头上的数据流名称只能是名词或名词短语,整个图中不反映加工的执行顺序。一般不画物质流。数据流反映能用计算机处理的数据,并不是实物,因此对目标系统的数据流图一般不要画物质流。每个加工至少有一个输入数据流和一个输出数据流,反映出此加工数据的来源与加工的结果。编号。如果一张数据流图中的某个加工分解成另一张数据流图时,则上层图为父图,直接

45、下层图为子图。子图及其所有的加工都应编号。 父图与子图的平衡。子图的输入输出数据流同父图相应加工的输入输出数据流必须一致,此即父图与子图的平衡。局部数据存储。当某层数据流图中的数据存储不是父图中相应加工的外部接口,而只是本图中某些加工之间的数据接口,则称这些数据存储为局部数据存储。提高数据流图的易懂性。注意合理分解,要把一个加工分解成几个功能相对独立的子加工,这样可以减少加工之间输入、输出数据流的数目,增加数据流图的可理解性。流程图的实例-销售管理系统 某企业销售管理系统的功能为: (1)接受顾客的订单,检验订单,若库存有货,进行供货处理,即修改库存,给仓库开备货单,并且将订单留底;若库存量不

46、足,将缺货订单登入缺货记录。 (2)根据缺货记录进行缺货统计,将缺货通知单发给采购部门,以便采购。 (3)根据采购部门发来的进货通知单处理进货,即修改库存,并从缺货记录中取出缺货订单进行供货处理。 (4)根据留底的订单进行销售统计,打印统计表给经理。 根据上述的功能描述,画出如下的数据流程图。3.4 数据字典(DD)数据字典(Data Dictionary,简称DD)就是用来定义数据流图中的各个成分的具体含义的,它以一种准确的、无二义性的说明方式为系统的分析、设计及维护提供了有关元素的一致的定义和详细的描述。它和数据流图共同构成了系统的逻辑模型,是需求规格说明书的主要组成部分。数据字典的内容以

47、及格式数据字典的任务是对于数据流图中出现的所有被命名的图形元素在数据词典中作为一个词条加以定义,使得每一个图形元素的名字都有一个确切的解释。数据字典有以下四类条目:数据流、数据项、数据存储、基本加工。数据词典中所有的定义应是严密的、精确的,不可有半点含混,不可有二义性。1.数据流条目 数据流条目给出了DFD中数据流的定义,通常列出该数据流的各组成数据项。在定义数据流或数据存储组成时,使用的符号如3-1表: 符号含义例及说明=被定义为+与x=a+b表示x由a和b组成.|.或x=a|b表示x由a或b组成m.n或.mn重复x=2a5表示x中最少出现2次a,最多出现5次a,2为重复次数的上、下限。.重

48、复x=a表示x由0个或多个a(.)可选x=(a)表示a可在x中出现,也可不出现。.基本数据元素x=a,表示x是取值为字符a的数据元素。.连接符x=1.9,表示x可取1到9中任意一个值。举例:定义数据流组成及数据项。机票=姓名+日期+航班号+起点+终点+费用姓名=字母航班号=“Y7100”.“Y8100”终点=上海|北京|西安数据流条目主要内容及举例如下:数据流名称:订单别名:无简述:顾客订货时填写的项目来源:顾客去向:加工1“检验订单”数据流量:1000份/每周组成:编号+订货日期+顾客编号+地址+电话+银行账号+货物名称+规格+数量2.数据存储条目数据存储条目是对数据存储的定义,如:数据存储

49、名称:库存记录别名:无简述:存放库存所有可供货物的信息组成:货物名称+编号+生产厂家+单价+库存量组织方式:索引文件,以货物编号为关键字查询要求:要求能立即查询3.数据项条目数据项条目是不可再分解的数据单位,其定义格式如下:数据项名称:货物编号别名:G-No,G-num,Goods-No简述:本公司的所有货物的编号类型:字符串长度:10取值范围及含义:第一位:进口/国产第2-4位:类别第5-7位:规格第8-10位:品名编号4.加工条目加工条目是用来说明DFD中基本加工的处理逻辑的,由于上层的加工是由下层的基本加工分解而来,只要有了基本加工的说明,就可理解其他加工。举例如下:加工名:查阅库存编号

50、:1.2激发条件:接收到合格订单时优先级:普通输入:合格订单输出:可供货订单、缺货订单加工逻辑:根据库存记录IF 订单项目的数量THEN 可供货处理ELSE 此订单缺货,登录,待进货后再处理ENDIF3.5 加工逻辑的描述 加工逻辑也称为“小说明”,描述加工逻辑一般用以下三种工具:结构化语言、判定表、判定树。结构化语言 结构化语言是介于自然语言和形式语言之间的一种半形式语言。结构化语言是在自然语言基础上加了一些限定,使用有限的词汇和有限的语句来描述加工逻辑,它的结构可分成外层和内层两层: (1)外层:用来描述控制结构,采用顺序、选择、重复三种基本结构。 (2)内层:一般是采用祈使语句的自然语言

51、短语,使用数据字典中的名词和有限的自定义词,其动词含义要具体,尽量不用形容词和副词来修饰。判定表 在有些情况下,数据流图中的某些加工的一组动作信赖于多个逻辑条件的取值。用自然语言或结构化语言都不易清楚地描述出来。而用判定表就能够清楚地表示复杂的条件组合与应做的动作之间的对应关系。 判定表由四个部分组成,如下3-2表所示,构造一张判定表,可采用以下步骤: (1)提取问题中的条件。 (2)标出条件的取值。 (3)计算所有条件的组合数N。(4)提取可能采用的动作或措施。 (5)制作判定表。 (6)完善判定表。 表3-2判定表结构条件定义条件取值的组合动作定义在各种取值的组合下应执行的动作 判定树 判

52、定树是判定表的变形,一般情况下它比判定表更直观,且易于理解和使用。 这三种描述加工逻辑的工具各有优缺点,对于顺序执行和循环执行的动作,用结构语言描述。对于存在多个条件复杂组合的判断问题,用判定表和判定树。判定树较判定表直观易读,判定表进行逻辑验证较严格,能把所有的可能性全部都考虑到。可将两种工具结合起来,先用判定表底稿,在经基础上产生判定树。3.6 IDEF方法IDEF方法是美国空军在1981年针对集成化计算机辅助制造(Integrated Computer Aided Manufacturing,简称ICAM)工程项目中用于进行复杂系统分析和设计的方法,是在结构化分析与设计技术的基础上提出来

53、的。IDEF是ICAM Definition的缩写。IDEF方法分为三部分。IDEF0: 用来描述系统的功能活动及其联系,建立系统的功能模型。IDEF1: 用来描述系统的信息以及其联系,建立系统的信息模型。IDEF2: 用来进行系统模拟,建立系统的动态模型。 IDEF0的图形表示IDEF0方法采用简单的图形符号和简洁的文字说明,描述系统在不同层次上的功能。在该方法中,将系统功能称为活动,将表示系统功能的图形称为活动图形。在活动图形中,用方框和箭头表示系统的各种活动及相互间的关系。3.6.2建立功能模型的基本方法1.确定建模的范围、观点及目的在开始为系统建立模型时,首先要确定建模的立足点,包括范

54、围、观点及目的。范围所讨论的对象是什么,它的边界和外部接口是什么;观点指从什么角度去考虑所研究的题;目的指确定所研究问题的意图及理由。2.建立系统的内外关系图-A-0图IDEF0方法建立的功能模型是一组有层次关系的图形,以字母A开头的编号来标志图形在层次中的位置。先建立系统的内外关系图,该图用来抽象地描述所研究的问题及其边界或数据接口。图中只有一个活动,活动名概括地描述系统的内容,用进入和离开的箭头表系统与环境的数据接口,确定了系统边界。3.建立顶层图-A-0图把A-0图分解为3-6个主要部分得到A0图,它清楚地表达了A-0图在同样信息范围内的细节,从结构上反映了模型的观点,是系统功能模型真正

55、的顶层图。该图中各方框所表示活动的详细含义由低层次的图形说明。4.建立低层次的图形按照自顶向下的方法,从A0图开始逐层分解,建立一系列的活动图形,直到最低层为止。第3章例题分析与解答/course_ware/software/test/show.asp?filename=3.txt&fname=第3章一、填空题1需求分析阶段,分析人员要确定对问题的综合需求,其中最主要的是_需求。 HYPERLINK /course_ware/software/test/show.asp?filename=3.txt&fname=第3章 l # 答案2结构化分析的基本思想是采用_的方法,能有效地控制系统开发的复

56、杂性。 HYPERLINK /course_ware/software/test/show.asp?filename=3.txt&fname=第3章 l # 答案3当数据流图中某个加工的一组动作存在着多个复杂组合的判断时,其加工逻辑使用_描述较好。 HYPERLINK /course_ware/software/test/show.asp?filename=3.txt&fname=第3章 l # 答案4在IDEF0图中,连在方框上的箭头有四种类型,它们分别是_。 HYPERLINK /course_ware/software/test/show.asp?filename=3.txt&fname

57、=第3章 l # 答案5为了较完整地描述用户对系统的需求,DFD应与数据库中的_图结合起来。 HYPERLINK /course_ware/software/test/show.asp?filename=3.txt&fname=第3章 l # 答案二、选择题1需求分析最终结果是产生( )。A.项目开发计划 B.可行性分析报告 C.需求规格说明书 D.设计说明书 HYPERLINK /course_ware/software/test/show.asp?filename=3.txt&fname=第3章 l # 答案2需求分析中,开发人员要从用户那里解决的最重要的问题是( )。A.要让软件做什么

58、B.要给该软件提供哪些信息C.要求软件工作效率怎样 D.要让该软件具有何种结构 HYPERLINK /course_ware/software/test/show.asp?filename=3.txt&fname=第3章 l # 答案3DFD中的每个加工至少有( )。A.一个输入流或一个输出流 B.一个输入流和一个输出流C.一个输入流 D.一个输出流 HYPERLINK /course_ware/software/test/show.asp?filename=3.txt&fname=第3章 l # 答案4数据字典中,一般不出现的条目是( )。A.数据流 B.数据存储 C.加工 D.源点与终点

59、HYPERLINK /course_ware/software/test/show.asp?filename=3.txt&fname=第3章 l # 答案5IDEF0图并不反映出系统( )。A.做什么 B.怎么做 C.谁来做 D.什么情况下做 HYPERLINK /course_ware/software/test/show.asp?filename=3.txt&fname=第3章 l # 答案应用题1 某银行计算机储蓄系统的功能是:将储户填写的存款单或取款单输入系统,如果是存款,系统记录存款人姓名、住址、存款类型、存款日期、利率等信息,并打印出存款单给储户;如果是取款,系统计 算清单给储户。

60、请用DFD和IDEF0描绘该功能的需求。 HYPERLINK /course_ware/software/test/show.asp?filename=3.txt&fname=第3章 l # 分析该题功能比较简单,首先找出该系统的外部环境,从而获得系统的输入输出。与该系统打交道的外部实体只有储户,输入有存取款原始单。该系统经过处理后,输出给储户正式的存款单或结算清单。这样,该系统的顶层DFD就确定了。其次,考虑该系统内部功能。系统要检验用户填写单据的合法性及区分存款还是取款,然后分别进行存款处理和取款处理。存款处理要登记储户的存款信息,需要建立数据存储文件;而取款处理要读取数据存储文件及查阅储

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论