第02章 可行性研究_第1页
第02章 可行性研究_第2页
第02章 可行性研究_第3页
第02章 可行性研究_第4页
第02章 可行性研究_第5页
已阅读5页,还剩72页未读 继续免费阅读

下载本文档

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

文档简介

1、1 软件工程基础 2 第1章课程回顾 u知识点回顾: l软件计算机系统中与硬件相互依存的另一部分,它 是包括程序、数据及其相关文档的完整集合。 l程序按事先设计的功能和性能要求编写的指令序列; 程序是完成指定功能的一段特定语言代码。 l数据使程序能正常操纵信息的数据结构。 l文档与程序开发、维护和使用有关的图文材料。 l软件危机软件开发和维护中过程中遇到的一系列严 重问题。 3 第1章课程回顾 u知识点回顾: l软件工程指研究软件生产的一门学科,也就是将 完善的工程原理应用于经济地生产既可靠又能在实际 机器上有效运行的软件。 l软件工程开发、运行、维护和修复软件的系统方 法。 l软件工程将系统

2、化的、规范的、可度量的方法应 用于软件的开发、运行和维护的过程,即将工程化应 用于软件中。 4 第1章课程回顾 l软件工程为了经济地获得可靠的和能在实际机器上 高效运行的软件而确立和使用健全的工程原理(方法)。 l软件工程方法学通常指在软件生命周期全过程中使 用的一整套技术的集合。软件工程方法学包括三个要素: 方法、工具和过程。 l软件生存期软件产品或软件系统从设计、投入使用 到被淘汰的全过程。一般说来,软件生存期由软件定义、 软件开发和软件维护三个时期组成,每个时期又可进一 步划分成若干个阶段。 5 第1章课程回顾 l软件危机的典型表现 (1) 对软件开发成本和进度的估计常常不很准确; (2

3、) 用户对“已完成的”软件系统不满意的现象经常发生; (3) 软件产品的质量往往靠不住; (4) 软件常常是不可维护的; (5) 软件通常没有适当的文档资料; (6) 软件成本在计算机系统中的比例逐年增加; (7) 软件开发生产率提高的速度远远跟不上计算机应用普 及速度。 6 第1章课程回顾 l 软件工程的本质特性 (1) 软件工程关注于大型程序的构造; (2) 软件工程的中心课题是控制复杂性; (3) 软件经常变化; (4) 开发软件的效率非常重要; (5) 和谐地合作是开发软件的关键; (6) 软件必须有效地支持它的用户; (7) 在软件工程领域中是由具有一种文化背景的人替具有 另一种文化

4、背景的人创造产品。 7 第1章课程回顾 l 软件工程中的7条基本原理 (1) 用分阶段的生命周期计划严格管理; (2) 坚持进行阶段评审; (3) 实行严格的产品控制; (4) 采用现代程序设计技术; (5) 结果应能够清楚地审查; (6) 开发小组的人员应该少而精; (7) 承认不断改进软件工程实践的必要性。 8 第1章课程回顾 l 常用的过程模型 生命周期模型规定了把生命周期划分成几个阶段及各 阶段的执行顺序,因此,也称过程模型。 常用的过程模型有瀑布模型、快速原型模型、增量 模型和螺旋模型等。 9 第2章可行性研究 u 2.1 可行性研究的任务 u 2.2 可行性研究过程 u 2.3 系

5、统流程图 u 2.4 数据流图 u 2.5 数据字典 u 2.6 成本/效益分析 u 2.7 可行性研究报告书写 10 2.1 可行性研究的任务 u可行性研究的任务是用最小的代价、在尽可能短的 时间内确定问题是否能够解决。 l首先进一步分析和澄清问题定义; l分析员应该导出系统的逻辑模型; l从逻辑模型出发,探索出若干种可供选择的主要解法 (即系统实现方案)。 l最后仔细研究每种解法的可行性。 l可行性研究的实质是一次大大压缩简化的系统分析和设 计过程。 11 2.1 可行性研究的任务 u 实例讲评1:两个整数乘法。 解法1 解法2 解法3 unsigned a , b , c; unsign

6、ed a , b; unsigned a, b; c=a*b; int c; long int c; c=a*b; c=a*b; 可能存在溢出问题! 不会存在溢出问题! 不存在溢出问题! 但不合理! 12 2.1 可行性研究的任务 u 可行性应该从下述几方面进行: l(1)技术可行性:指使用现有的技术能否完成这个 项目,度量一个特定技术信息系统解决方案的实用性 及技术资源的可用性。 开发风险分析:最新技术成熟度等。 资源分析:人力消耗、财力消耗、时间消耗等。 相关技术的发展(现有技术能否实现新系统,技 术难点、建议采用技术的先进性) 13 2.1 可行性研究的任务 l (2)经济可行性:指通过

7、对软件开发项目进行成 本/效益估计,以确定软件系统可能带来的经济效益 能否超过研制和维护此系统所需的费用。度量系统 解决方案的性能价格比。 成本/效益分析 有形成本、效益 无形成本、效益 价值和成本的关系 质量与价值、成本的关系 价值/成本的均衡 14 2.1 可行性研究的任务 l(3)操作可行性 用户使用可能性:公共汽车非接触式感应卡用输入密码 或指纹来代替。 时间进度可行性 组织和文化上的可行性 l(4)社会因素的考虑:软件开发是否会侵犯他人、集体或 国家的利益。 u实质:一次简化的、高层次的、抽象的分析和设计 过程! 15 2.1 可行性研究的任务 u 实例讲评2:“求一元二次方程的解”

8、可行性。 l问题定义:这是一个简单的数学问题(什么问题);系统要 求不高,整系数方程(怎样要求);用于初中教学(哪里应 用);解法简单(结论如何)。 l技术上分析:能,简单 此方程可以根据判别式b2-4ac的值来确定方程根的 情况, 即:b2-4ac0 时有两个不等实根;b2-4ac=0 时有相等的两个实根;b2-4ac 0时有共轭复数根。 a ,b , c取值(unsigned , int , longint , float)类型影响 求解过程和求解算法。 16 2.1 可行性研究的任务 l经济上分析:略 l 社会效益上分析:略 l 操作上:键盘、鼠标、语音提示、触摸屏等 17 2.1 可行

9、性研究的任务 u 实例讲评3:系统开发和每年运行费用举例 l1.系统开发费用(一次) .2名系统分析员(450小时/名,45美元/小时) $40,500 .5名系统开发人员(275小时/名,36美元/小时) $49,500 .1名数据库管理员(30小时/名,42美元/小时) $1,260 .2名技术写作者(120小时/名,25美元/小时) $ 6,000 .1名秘书(160小时/名,15美元/小时) $ 2,400 .1名数据通讯专家(60小时/名,42美元/小时) $2,520 .2名在转换期间数据输入人员(40小时/名,12美元/小时)$960 合计 $103,140 18 2.1 可行性

10、研究的任务 l 2.培训: 三天的开发人员内部培训课程 $7,000 30个用户,三天的内部培训课程 $10,000 l 3.物资: 复印 $500 磁盘、纸张等消耗品 $650 19 2.1 可行性研究的任务 购买硬件、软件: 20台工作站Windows软件 $1,000 20台工作站内存升级 $8,000 网络软件 $17,500 20台工作站办公软件产品 $20,000 系统开发总费用$161,670 20 2.1 可行性研究的任务 l4.年运行费用(每年) 人员: 维护程序员/分析员(250小时/年,42美元/小时) $10,500 网络管理员(300小时/年,50美元/小时) $15

11、,000 购买硬件、软件升级: 硬件 $5,000 软件 $6,000 物资和杂项 $3,500 每年总运行费用 $40,000 21 2.1 可行性研究的任务 u可行性研究的任务 l(1)明确目的 1确定问题是否能够解决; 2是否值得解决! l(2)确定内容 1问题定义:明确系统目标、规模和约束条件 2导出系统逻辑模型:系统流程图、数据流图等 l3提供可选解决方案 22 2.1 可行性研究的任务 l4可行性(内涵)分析:技术/经济/操作/维护分析等等; l 5每个方案的粗略进度; l 6方案选择建议。 u可行性研究成本:5%10%。 23 2.2 可行性研究过程 u(1)复查系统规模和目标

12、l定义问题 l 复查定义阶段的报告书,清晰限制和约束:目标、 规模、全部约束 u(2)研究目前正在使用的系统 l1分析已有或相关系统技术和应用现状:找问题/ 总体上 l 2分析系统的技术文档和使用手册:了解问题、 挖掘问题/微观上 24 2.2 可行性研究过程 l3实地考察现有系统:what/why/how l 4重点在于“能做什么”,而不是“如何做什么”。 即:只关心高层系统流程图 l 5避免花费过多时间分析现有系统 l 6关注约束条件 u(3)导出新系统的高层逻辑模型 l现有的物理系统现有系统的逻辑模型目标系 统的逻辑模型新的物理系统 25 2.2 可行性研究过程 u(4)重新定义问题 l

13、1以数据流图、数据字典为基础 l 2需要得到用户的认可,避免疏漏、误解 l 3这是一个循环过程,直到完全符合系统要求 u(5)导出和评价供选择的方案 l1从技术角度解决的不同方案:eg1:控件和程序;eg2: 中断与查询 26 2.2 可行性研究过程 l2从操作方面的可行性:管理习惯、行为习 惯、人员素质等; l 3从经济方面的可行性:开发成本/运行成 本/开支变化等 l 4确定进度表 u(6)推荐方案和行动方针 l分析员给出结论给出理由 27 2.2 可行性研究过程 u(7)草拟开发计划 l1进度表; l 2人力资源:系统分析员、程序员、资 料员等; l 3设备资源等。 u(8)书写文档、提

14、交审查 28 2.3 系统流程图 u系统流程图是描绘物理系统的传统工具,它的基 本思想是用图形符号以黑盒子形式描绘系统里面 的每一个部件(程序、文件、数据库、表格、人 工过程等)。 l尽管系统流程图使用的某些符号和程序流程图所用的 符号相同,但系统流程图表达的是信息在系统中各个 部件之间流动的情况,而不是对信息进行加工处理的 控制过程。 29 2.3 系统流程图 30 2.3 系统流程图 31 2.3 系统流程图 32 2.3 系统流程图 33 2.3 系统流程图 u实例讲评6:仓库订货管理系统之系统流程图 34 2.3 系统流程图 u实例讲评7:口算高手之系统流程图 35 2.4 数据流图

15、u数据流图英文Data Flow Diagram ,简称DFD u DFD是一种描述逻辑模型的图形工具,表示数据在 系统内的变化。 u 图中没有任何具体的物理元素,只是描绘信息在系 统中流动和处理的情况。 u DFD从数据传递和加工的角度,以图形的方式刻画 数据流从输入到输出的移动变换过程。 36 2.4 数据流图 u数据流图中的符号/图形元素: l 正方形:源点或终点; l 圆角矩形:处理; l 开口矩形:数据存储; l 箭头:流动方向 37 2.4 数据流图 l数据流图的基本图形元素 (1)数据流:是一组数据。在数据流图中数据流 用带箭头的线表示,在其线旁标注数据流名。 (2)加工:是对数

16、据流执行的某种操作或变换。 在数据流图中加工用圆圈表示,在圆圈内写上加 工名。 (3)文件:是按照某种规则组织起来的、长度不 限的数据。在数据流图中文件用一直线表示,在 线段旁注上文件名。 (4)数据流的源点和终点:在数据流图中用方框 表示,在框内写上相应的名称。 38 2.4 数据流图 u由外向里画数据流图的步骤/画法 l(1)确定系统的输入输出 由于系统究竟包括哪些功能可能一时难于弄清楚,可使 范围尽量大一些,把可能有的内容全部都包括进去。 应该向用户了解“系统从外界接受什么数据”、“系统 向外界送出什么数据”等信息。 根据用户的答复画出数据流图的外围。 39 2.4 数据流图 l (2)

17、由外向里画系统的顶层数据流图 首先,将系统的输入数据和输出数据用一连串的加工连接 起来。 在数据流的值发生变化的地方就是一个加工。 给各个加工命名。 然后,给加工之间的数据命名。 最后,给文件命名。 40 2.4 数据流图 l(3)自顶向下逐层分解,绘出分层数据流图 对于大型的系统,为了控制复杂性,便于理解, 需要采用自顶向下逐层分解的方法进行,即用 分层的方法将一个数据流图分解成几个数据流 图来分别表示。 uDFD可以用来表示一个系统或软件在任何层次上的 抽象。较大型软件系统DFD分成多层(子图、父图概 念),可以表示数据流和功能的进一步的细节。 41 2.4 数据流图 u实例讲评8:仓库订

18、货系统数据流图实例 42 2.4 数据流图 43 2.4 数据流图 44 2.4 数据流图 45 2.4 数据流图 46 2.4 数据流图 u实例讲评9:口算高手的输入/输出 47 2.4 数据流图 u实例讲评9:口算高手顶层数据流图 48 2.4 数据流图 u实例讲评10:客房管理系统输入/输出 49 2.4 数据流图 u实例讲评10:客房管理系统局部DFD 50 2.4 数据流图 u绘制数据流图的注意事项: l1 合理细化。 l 2 分层细化时必须保持信息的连续性。 l 3 注意处理的编号和适当地命名。 l 4 画数据流而不是控制流。 l 5 先考虑稳定状态。 l 6 忽略琐碎的枝节。 5

19、1 2.4 数据流图 l7 随时准备重画。 l 8 注意程序流程图与数据流图的区别。数据流图描绘 所有可能,而不应该描绘出现某个数据流的条件。 l 9 数据流图基本要点是要回答“作什么”,而不是 “怎样作”。 52 2.4 数据流图 l10 命名:直接影响到数据流图的可理解性。 1为数据流/数据存储命名:代表整个数据流内容/切 忌空洞/必要时考虑重新分解; 2为处理命名:先数据流,后处理/代表整个功能/及 物动词+宾语/一般只包含一个动词/必要时考虑重新 分解; 53 2.5数据字典 u数据字典英文Data Dictionary,简称DD u DD定义:对于数据流图中所出现的所有被命名的 图形

20、元素作为一个词条加以定义,使得每一个图 形元素的名字都有一个确切的解释。 lDD是对所有与系统相关的数据元素的一个有组织的列表, 以及精确的、严格的定义,使得用户和系统分析员对于 输入、输出、存储成分和中间计算有共同的理解。 54 2.5数据字典 uDD是一种描述逻辑模型的工具。 u DD是数据的信息集合,是对数据流图中包含的所 有元素的定义的集合。 u DD的内容包括:图形元素的名字、别名或编号、 分类、描述、定义、位置等。 u 典型DD包括: l一般信息:名字,别名,描述等; l 定义:数据类型,长度,结构等; 55 2.5 数据字典 l使用特点:值范围,使用频率, l 使用方法:输入/输

21、出/本地/网络/条件值等; l 控制信息:来源/用户/使用它的程序/使用权/改变权等; l 分组信息:复结构/从属结构/物理位置等; 56 2.5数据字典 u使用DD的目的 l查阅不了解的条目的解释; l 尽量减少出现别名; l DD中所有的定义都应是严密的、精确的,不可有半点含 混,不可有二义性。 l 数据流图和数据字典共同构成系统的逻辑模型。 57 2.5数据字典 u 数据字典DD中常用符号的含义。 58 2.5数据字典 l 数据字典中定义数据的方法: 自顶向下分解数据 数据元素组成方式类型 顺序/选择/重复/可选 l数据字典的用途:分析阶段的重要工具。 l数据字典的实现: 全人工过程;

22、全自动化工程; 混合过程; 59 2.5数据字典 l 字典与数据流图之间关系 数据流图描述了系统的“分解”; 依靠“字典”来说明各个成分的含义; 数据流图中所有名字的定义就构成一本词典; 数据流图和字典结合在一起构成了“需求说明书”; 数据流图中出现的每一个数据流名、每一个文件名和每 一个加工名在词典中都应该有一个条目给出这个名字的 定义。 60 2.5数据字典 l 字典条目的各种类型 数据流 文件 数据项(指不在分解的数据单位) 加工 l小说明 数据流图中每一个基本加工(即不再进一步被分 解的加工)都必须有一个“小说明”; 小说明中应精确描述用户要求一个加工“做什 么”: 61 2.5数据字

23、典 u实例讲评11:口算高手字典建模 计算整数=十进制1数字2 统计命令= 1字母1 计算结果输出= 2字母3 统计结果输出= 2字母2+十进制1数字2+ 4字母4+十进制1数字2 十进制数字“0”“9” 字母“A”“Z” 62 2.5 数据字典 u 实例讲评12:客房管理系统字典建模 预订请求客人数据住宿期限+客房类别 客人数据客人姓名+地址+身份证号码 +护照号码 +支付方式 身份证号码=十进制15数字18 护照号码字母+ 8数字8 字母“A”“Z” 十进制数字“0”“9” 63 2.5数据字典 u实例讲评13:航班词典条目实例 F1: 航班信息文件航空公司名称航班号 起点终点日期起飞时间

24、降落 时间 航空公司名称2字母4 航班号3十进制数字3 字母“A”“Z” 十进制数字“0”“9” 起点终点1汉字10 起飞时间降落时间时分 64 2.5数据字典 时“00”“23” 分“00”“59” 日期年月日 年2000200120022003|2004|2005 月“01”“12” 日“01”“31” 65 2.5数据字典 u 实例讲评14:路灯管理系统数据字典 66 2.5数据字典 67 2.6 成本/效益分析 u成本/效益分析的目的,是从经济角度评价开发一 个新项目是否可行、是否划算,从而帮助使用部 门的负责人正确地作出是否投资于这项开发的决 定。 u成本估计 l代码行技术:通常先根

25、据经验和历史数据来估计实 现一个功能所需要的源程序行数,然后用每行代码 的平均成本乘以行数就可以确定软件的成本。 68 2.6 成本/效益分析 l 任务分解技术: 首先把软件开发工程分解为若干个相对独立的任务, 再分别估计每个单独的开发任务的成本,最后累加起 来得出软件开发工程的总成本。 估计每个任务的成本时,通常先估计完成该项任务所 需要使用的人力(以人月为单位),再乘以每人每月 的平均工资而得出每个任务的成本。 划分任务时最常用的办法是按开发阶段进行。 69 2.6 成本/效益分析 u度量效益的方法 l货币的时间价值 货币的时间价值通常用利率的形式表示。假设 年利率为i,如果现在存入P元,则n年后可以得 到的钱数为: FP(1十i)n 这也就是P元钱在n年后的价值。反之,如 果n年后能收入F元钱,那么这些钱的现在的价 值是: PF(1十i)n 70 2.6 成本/效益分析 l投资回收期:所谓投资回收期就是使累计的经济效益等于 最初投资所需要的时间。显然,投资回收期越短就能越快 获得利润,这项工程也就越值得投资

温馨提示

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

评论

0/150

提交评论