软件工程电子教案第2章课件.ppt
- 【下载声明】
1. 本站全部试题类文档,若标题没写含答案,则无答案;标题注明含答案的文档,主观题也可能无答案。请谨慎下单,一旦售出,不予退换。
2. 本站全部PPT文档均不含视频和音频,PPT中出现的音频或视频标识(或文字)仅表示流程,实际无音频或视频文件。请谨慎下单,一旦售出,不予退换。
3. 本页资料《软件工程电子教案第2章课件.ppt》由用户(三亚风情)主动上传,其收益全归该用户。163文库仅提供信息存储空间,仅对该用户上传内容的表现方式做保护处理,对上传内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知163文库(点击联系客服),我们立即给予删除!
4. 请根据预览情况,自愿下载本文。本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
5. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007及以上版本和PDF阅读器,压缩文件请下载最新的WinRAR软件解压。
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 软件工程 电子 教案 课件
- 资源描述:
-
1、第2章 可行性研究2.1 可行性研究的任务2.2 可行性研究过程2.3 系统流程图2.4 数据流图2.5 数据字典第1页,共66页。2.6 成本/效益分析2.7 小结习题第2页,共66页。1、目的:可行性研究的目的不是解决问题,而是确定问题是否值得去解决。用最小的代价在尽可能短的时间内,确定问题是否能够解决。因此,可行性研究实质上是进行一次大大压缩简化了的系统分析和设计的过程,也就是在较高层次上以较抽象的方式进行的系统分析和设计的过程。2.1 可行性研究的任务第3页,共66页。2、任务:初步确定了项目的规模、目标和限制条件。分析员导出系统的逻辑模型。然后探索若干种可供选择的系统实现方案。一般说
2、来,从下述三方面研究每种方案的可行性。技术可行性 使用现有的技术能实现这个系统吗?(2)经济可行性 这个系统的经济效益能超过它的开发成本吗?(3)操作可行性 系统的操作方式在这个用户组织内行得通吗?必要时还应该从法律、社会效益等更广泛的方面研究操作的可行性。第4页,共66页。3、时间、成本 可行性研究需要的时间长短取决于工程的规模。一般说来,可行性研究的成本只是预期的工程总成本的5%10%。分析员应该为每个可行的方案制定一个粗略的实现进度。可行性研究最根本的任务是对以后的行动方针提出建议。如果问题没有可行的解,分析员应该建议停止这项开发工程,以避免时间、资源、人力和金钱的浪费;如果问题值得解,
3、分析员应该推荐一个较好的解决方案,并且为工程制定一个初步的计划。第5页,共66页。典型的可行性研究过程一般按下述步骤做:第一步:复查系统规模和目标分析员访问关键人员,仔细阅读和分析有关的材料,以便对问题定义阶段书写的关于规模和目标的报告书进一步复查确认,改正含糊或不确切的叙述,清晰地描述对目标系统的一切限制和约束。这个步骤的工作,实质上是为了确保分析员正在解决的问题确实是要求他解决的问题。2.2 可行性研究过程第6页,共66页。第二步:研究目前正在使用的系统现有的系统是信息的重要来源。(1)新的目标系统必须也能完成它的基本功能;(2)现有的系统必然有某些缺点,新系统必须能解决旧系统中存在的问题
4、。(3)运行使用旧系统所需要的费用是一个重要的经济指标,如果新系统不能增加收入或减少使用费用,那么从经济角度看新系统就不如旧系统。(4)分析员应该画出描绘现有系统的高层系统流程图(见2.3节),并请有关人员检验他对现有系统的认识是否正确。千万不要花费太多时间去了解和描绘现有系统的实现细节。(5)应该注意了解并记录现有系统和其他系统之间的接口情况,这是设计新系统时的重要约束条件。第7页,共66页。第三步:导出新系统的高层逻辑模型 优秀的设计过程通常总是从现有的物理系统出发,导出现有系统的逻辑模型,再参考现有系统的逻辑模型,设想目标系统的逻辑模型,最后根据目标系统的逻辑模型建造新的物理系统。通过前
5、一步的工作,分析员对目标系统应该具有的基本功能和所受的约束已有一定了解,能够使用数据流图(参看2.4节),描绘数据在系统中流动和处理的情况,从而概括地表达出他对新系统的设想。通常为了把新系统描绘得更清晰准确,还应该有一个初步的数据字典(参看2.5节),定义系统中使用的数据。数据流图和数据字典共同定义了新系统的逻辑模型,以后可以从这个逻辑模型出发设计新系统。第8页,共66页。第四步:进一步定义问题新系统的逻辑模型实质上表达了分析员对新系统必须做什么的看法。分析员应该和用户一起再次复查问题定义、工程规模和目标,这次复查应该把数据流图和数据字典作为讨论的基础。如果分析员对问题有误解或者用户曾经遗漏了
6、某些要求,那么现在是发现和改正这些错误的时候了。可行性研究的前4个步骤实质上构成一个循环。分析员定义问题,分析这个问题,导出一个试探性的解;在此基础上再次定义问题,再一次分析这个问题,修改这个解;继续这个循环过程,直到提出的逻辑模型完全符合系统目标。第9页,共66页。第五步:导出和评价供选择的解法分析员应该从他建议的系统逻辑模型出发,导出若干个较高层次的(较抽象的)物理解法供比较和选择。导出供选择的解法的最简单的途径,1)是从技术角度出发考虑解决问题的不同方案。还可以使用组合的方法导出若干种可能的物理系统。当从技术角度提出了一些可能的物理系统之后,应该根据技术可行性的考虑初步排除一些不现实的系
7、统。把技术上行不通的解法去掉之后,就剩下了一组技术上可行的方案。第10页,共66页。2)考虑操作方面的可行性。分析员应该根据使用部门处理事务的原则和习惯检查技术上可行的那些方案,去掉其中从操作方式或操作过程的角度看用户不能接受的方案。3)考虑经济方面的可行性。分析员应该估计余下的每个可能的系统的开发成本和运行费用,并且估计相对于现有的系统而言这个系统可以节省的开支或可以增加的收入。在这些估计数字的基础上,对每个可能的系统进行成本/效益分析(参看2.6节)。一般说来,只有投资预计能带来利润的系统才值得进一步考虑。4)为每个在技术、操作和经济等方面都可行的系统制定实现进度表,这个进度表不需要(也不
8、可能)制定得很详细,通常只需要估计生命周期每个阶段的工作量。第11页,共66页。第六步:推荐行动方针根据可行性研究结果应该做出的一个关键性决定是,是否继续进行这项开发工程。分析员必须清楚地表明他对这个关键性决定的建议。如果分析员认为值得继续进行这项开发工程,那么他应该选择一种最好的解法,并且说明选择这个解决方案的理由。通常使用部门的负责人主要根据经济上是否划算决定是否投资于一项开发工程,因此分析员对于所推荐的系统必须进行比较仔细的成本/效益分析。第12页,共66页。第七步:草拟开发计划分析员应该为所推荐的方案草拟一份开发计划,除了制定工程进度表之外还应该估计对各类开发人员和各种资源的需要情况,
9、应该指明什么时候使用以及使用多长时间。此外还应该估计系统生命周期每个阶段的成本。最后应该给出下一个阶段(需求分析)的详细进度表和成本估计。第八步:书写可行性研究报告提交审查 按照标准书写清晰可行性研究报告文档,请用户、客户组织的负责人及评审组审查,以决定是否继续这项工程及是否接受分析员推荐的方案。第13页,共66页。1、系统流程图 是概括地描绘物理系统的传统工具。它是用图形符号(以黑盒子形式)描绘组成系统的各个元素(程序,文档,数据库,人工过程等)和信息在这些元素之间的流动情况。2、系统流程图和程序流程图的相同与不同相同:系统流程图的某些符号和程序流程图的符号 形式相同。不同:系统流程图表达的
10、是数据在系统各部件之间流动的情况,而不是对数据进行加工处理的控制过程。是物理数据流图而不是程序流程图。2.3 系统流程图第14页,共66页。当以概括的方式抽象地描绘一个实际系统时,仅仅使用图2.1中列出的基本符号就足够了。当需要更具体地描绘一个物理系统时还需要使用图2.2(见书29页)中列出的系统符号,利用这些符号可以把一个广义的输入输出操作具体化为读写存储在特殊设备上的文件(或数据库),把抽象处理具体化为特定的程序或手工操作等。2.3.1 符号第15页,共66页。图2.1 基本符号第16页,共66页。介绍系统流程图的最好方法可能是通过一个具体例子说明它的用法。下面是一个简单的例子。某装配厂有
11、一座存放零件的仓库,仓库中现有的各种零件的数量以及每种零件的库存量临界值等数据记录在库存清单主文件中。当仓库中零件数量有变化时,应该及时修改库存清单主文件,如果哪种零件的库存量少于它的库存量临界值,则应该报告给采购部门以便定货,规定每天向采购部门送一次定货报告。2.3.2 例子第17页,共66页。1、该厂使用一台小型计算机处理更新库存清单主文件和产生定货报告的任务。2、零件库存量的每一次变化称为一个事务,由放在仓库中的CRT终端输入到计算机中;3、系统中的库存清单程序对事务进行处理,更新存储在磁盘上的库存清单主文件,并且把必要的定货信息写在磁带上。4、最后,每天由报告生成程序读一次磁带,并且打
12、印出定货报告。图2.3的系统流程图描绘了上述系统的概貌。图中每个符号用黑盒子形式定义了组成系统的一个部件,然而并没有指明每个部件的具体工作过程;图中的箭头确定了信息通过系统的逻辑路径。第18页,共66页。信息从顶向下 或从左向右流动图2.3 库存清单系统的系统流程图第19页,共66页。面对复杂的系统时,一个比较好的方法是分层次地描绘这个系统。首先用一张高层次的系统流程图描绘系统总体概貌,表明系统的关键功能。然后分别把每个关键功能扩展到适当的详细程度,画在单独的一页纸上。这种分层次的描绘方法便于阅读者按从抽象到具体的过程逐步深入地了解一个复杂的系统。2.3.3 分层第20页,共66页。数据流图(
13、DFD)是一种图形化技术,它以图形的方式描绘信息流和数据在系统中的流动和被处理的逻辑过程。数据流图是系统逻辑功能的图形表示,即使不是专业的计算机技术人员也容易理解它,因此是分析员与用户之间极好的通信工具。此外,设计数据流图时只需考虑系统必须完成的基本逻辑功能,完全不需要考虑怎样具体地实现这些功能,所以它也是今后进行软件设计的很好的出发点。2.4 数据流图第21页,共66页。如图2.4(a)(见书31页)所示,数据流图有四种基本符号:1、正方形(或立方体)表示数据的源点或终点;2、圆角矩形(或圆形)代表变换数据的处理;3、开口矩形(或两条平行横线)代表数据存储;4、箭头表示数据流,即特定数据的流
14、动方向。注意:1、数据流与程序流程图(参看本书第5章)中用箭头表示的控制流有本质不同,千万不要混淆。在数据流图中应该描绘所有可能的数据流向,而不应该描绘出现某个数据流的条件。2.4.1 符号第22页,共66页。2、处理并不一定是一个程序。一个处理框可以代表一系列程序、单个程序或者程序的一个模块;它甚至可以代表用穿孔机穿孔或目视检查数据正确性等人工处理过程。3、一个数据存储也并不等同于一个文件,它可以表示一个文件、文件的一部分、数据库的元素或记录的一部分等;4、数据可以存储在磁盘、磁带、磁鼓、主存、微缩胶片、穿孔卡片及其他任何介质上(包括人脑)。第23页,共66页。5、数据存储和数据流都是数据,
15、仅仅所处的状态不同。数据存储是处于静止状态的数据,数据流是处于运动中的数据。6、数据流图的基本要点是描绘“做什么”而不考虑“怎样做”。通常在数据流图中忽略出错处理,也不包括诸如打开或关闭文件之类的内务处理。第24页,共66页。除了上述4种基本符号之外,有时也使用几种附加符号。图2.4(b)给出了这些附加符号的含义。TTT第25页,共66页。假设一家工厂的采购部每天需要一张定货报表,报表按零件编号排序,表中列出所有需要再次定货的零件。对于每个需要再次定货的零件应该列出下述数据:零件编号,零件名称,定货数量,目前价格,主要供应者,次要供应者。零件入库或出库称为事务,通过放在仓库中的CRT终端把事务
16、报告给定货系统。当某种零件的库存数量少于库存量临界值时就应该再次定货。2.4.2 例子第26页,共66页。数据流图画法1、先画顶层数据流图,既只包含一个处理的图。先画数据源点与终点(系统的输入输出);数据源点:对系统的描述可以知道“通过放在仓库中的CRT终端把事务报告给定货系统”所以仓库管理员是数据源点。数据终点:“采购部每天需要一张定货报表”所以采购员是数据终点。数据的处理:“采购部需要报表”,显然他们还没有这种报表,因此必须有一个用于产生报表的处理。数据流和数据存储:系统把定货报表送给采购部,因此定货报表是一个数据流;事务需要从仓库送到系统中,显然事务是另一个数据流。第27页,共66页。图
17、2.5 定货系统的基本系统模型第28页,共66页。2、细化数据流程图。图2.5毕竟太抽象了,从这张图上对定货系统所能了解到的信息非常有限。下一步应该把基本系统模型细化,描绘系统的主要功能。从图2.5可知,“产生报表”和“处理事务”是系统必须完成的两个主要功能,它们将代替图2.5中的“定货系统”(图2.6)。第29页,共66页。图2.6 定货系统的功能级数据流图第30页,共66页。3、接下来应该对功能级数据流图中描绘的系统主要功能进一步细化。考虑通过系统的逻辑数据流:当发生一个事务时必须首先接收它;随后按照事务的内容修改库存清单;最后如果更新后的库存量少于库存量临界值时,则应该再次定货,也就是需
18、要处理定货信息。因此,把“处理事务”这个功能分解为下述3个步骤,这在逻辑上是合理的:“接收事务”、“更新库存清单”和“处理定货”(图2.7)。当对数据流图分层细化时必须保持信息连续性,也就是说,当把一个处理分解为一系列处理时,分解前和分解后的输入输出数据流必须相同。第31页,共66页。图2.7 把处理事务的功能进一步分解后的数据流图第32页,共66页。画数据流图的原则(注意事项)1、数据流图上所有图形符号只限于前述四种基本图形元素。2、每个加工至少有一个输入数据流和一个输出数据流,反映出此加工数据的来源与结果。3、图上每个元素都必须有名字。4、画数据流不是画控制流,只反映系统“做什么”,不反映
19、“如何做”。整个图不反映加工的执行顺序。5、编号:需按层给处理框编号。编号表明该处理处在哪一层以及上下图父图与子图的关系。6、父图与子图的平衡。子图的输入输出数据流同父图相应处理的输入输出必须一致。第33页,共66页。7、存储:一个局部存储只要当它作为某些处理的数据接口或某个处理特定的输入输出时,就要把它画出来,有助于实现信息的隐蔽。8、提高数据流图的易理解性。(1)注意合理分解;(2)分解时注意字处理的独立性与均匀性;(3)不要在一张图上有些是基本处理,有些处理还要分解好几层。第34页,共66页。数据流图中每个成分的命名是否恰当,直接影响数据流图的可理解性。因此,给这些成分起名字时应该仔细推
20、敲。下面讲述在命名时应注意的问题:1.为数据流(或数据存储)命名(1)名字应代表整个数据流(或数据存储)的内容,而不是仅仅反映它的某些成分。(2)不要使用空洞的、缺乏具体含义的名字(如“数据”、“信息”、“输入”之类)。(3)数据流只反映系统“做什么”,不反映“如何做”,名字只能是名词或名词短语。2.4.3 命名第35页,共66页。(4)如果在为某个数据流(或数据存储)起名字时遇到了困难,则很可能是因为对数据流图分解不恰当造成的,应该试试重新分解,看是否能克服这个困难。2.为处理命名(1)通常先为数据流命名,然后再为与之相关联的处理命名。这样命名比较容易,而且体现了人类习惯的“由表及里”的思考
展开阅读全文