软件工程导论课后习题答案
软件工程导论(第六版)部分课后习题-答案

软件工程导论(第六版)部分课后习题-答案软件工程导论(第六版)部分课后习题-答案一、选择题1. 答案:B解析:选择题解析2. 答案:A解析:选择题解析二、判断题1. 答案:对解析:判断题解析2. 答案:错解析:判断题解析三、填空题1. 答案:软件工程解析:填空题解析2. 答案:开发、维护解析:填空题解析四、简答题1. 答案:软件需求分析是软件工程的第一步,它主要是通过对用户需求的调查和分析,确定软件系统需要具备的功能和性能以及相关约束条件。
解析:简答题解析2. 答案:软件开发过程中的质量保证主要包括软件测试和代码评审两个方面。
软件测试是通过运行和验证软件系统的过程,以确定其是否满足预期的需求和标准。
代码评审则是对软件代码进行审查和评估,在开发过程中发现和修复潜在的问题和错误。
解析:简答题解析五、计算题1. 答案:20解析:计算题解析2. 答案:1000解析:计算题解析六、案例分析题1. 答案:软件项目管理是指对软件项目进行规划、组织、分配和控制的过程。
它包括项目范围管理、时间管理、成本管理、质量管理、风险管理等方面。
在一个项目中,软件项目经理负责整体的项目管理工作,包括资源的分配、进度的控制、风险的管理等。
解析:案例分析题解析2. 答案:敏捷开发是一种迭代、逐步增量的软件开发方法。
它强调快速、灵活地响应用户需求的变化,通过频繁的迭代和持续的反馈来逐步完善软件系统。
敏捷开发方法注重团队合作、交流和高效的沟通,通过直接面对面的沟通取代冗长的文档和繁琐的流程,提高软件开发的效率和质量。
解析:案例分析题解析总结:本文主要针对《软件工程导论(第六版)》部分课后习题提供了答案和解析。
其中包括选择题、判断题、填空题、简答题、计算题和案例分析题等多个题型。
通过解答这些习题,读者可以进一步加深对软件工程的理解和掌握。
希望本文对读者有所帮助,谢谢阅读。
软件工程导论课后习题解答

第一章1-1什么是软件危机?答:是指在计算机软件的开发和维护过程中所遇到的一系列严重问题。
1-3什么是软件工程?答:是指导计算机软件开发和维护的一门工程学科。
1-4简述结构化范型和面向对象范型的要点,并分析它们的优缺点。
答:目前使用得最广泛的软件工程方法学有2种:传统方法学:也称为生命周期方法学或结构化范型。
优点:把软件生命周期划分成若干个阶段,每个阶段的任务相对独立,而且比较简单,便于不同人员分工协作,从而降低了整个软件开发过程的困难程度。
缺点:当软件规模庞大时,或者对软件的需求是模糊的或会随着时间而变化的时候,开发出的软件往往不成功;而且维护起来仍然很困难。
面向对象方法学:优点:降低了软件产品的复杂性;提高了软件的可理解性;简化了软件的开发和维护工作;促进了软件重用。
1-5、根据历史数据可以做出如下的假设:对计算机存储容量的需求大致按下面公式描述的趋势逐年增加:M = 4080 e0.28(Y-1960)存储器的价格按下面公式描述的趋势逐年下降:P1 = 0.3×0.72Y-1974(美分/位)如果计算机字长为16位,则存储器价格下降的趋势为:P2 = 0.048×0.72Y-1974(美元/字)在上列公式中Y代表年份,M是存储容量(字数),P1和P2代表价格。
基于上述假设可以比较计算机硬件和软件成本的变化趋势。
要求计算:(1) 在1985年对计算机存储容量的需求估计是多少?如果字长为16位,这个存储器的价格是多少?(2) 假设在1985年一名程序员每天可开发出10条指令,程序员的平均工资是每月4000美元。
如果一条指令为一个字长,计算使存储器装满程序所需用的成本。
(3) 假设在1995年存储器字长为32位,一名程序员每天可开发出30条指令,程序员的月平均工资为6000美元,重复(1)、(2)题。
(1)在1985年对计算机存储容量的需求,估计是M= 4080 e0.28(1985-1960)= 4080 e7=4474263(字)如果字长为16位,则这个存储器的价格是P= 0.048 × 0.721995-1974× 73577679 = 5789(美元)(2)如果一条指令的长度为一个字,则使存储器装满程序共需4474263条指令。
软件工程导论张海藩课后习题答案(完整版)

作业及解答(第4章)
其中, ✓符号∷=表示定义为; ✓符号[...]表示可选项; ✓符号a|b表示a或b。 假设有这样一个有穷状态机:以一串字符为输入,判断字符 串中是否含有合法的浮点二进制数。试对这个有穷状态机进 行规格说明。
作业及解答(第4章)
该有穷状态机的初态是“等待字符串输人”。在初态若接收 到字符十、或字符一、或二进制位,则进人“输人尾数” 状态;在初态若接收到其他字符,则进人终态“非浮点二 进制数”。在“输人尾数”状态若接收到二进制位,则保 持该状态不变;若接收到字符 E ,则进人“等待输人指数 ”状态;若接收到其他字符,则进人终态“非浮点二进制 数”。在“等待输人指数”状态若接收到字符+、或字符 一、或二进制位,则进人“输人指数”状态;若接收到其 他字符,则进人终态“非浮点二进制数”。在“输人指数 ”状态若接收到二进制位,则保持该状态不变;若输人其 他字符,则进人终态“非浮点二进制数”;若输人结束, 则进人终态“浮点二进制数”。
E2 病人
F2生理信号
E3 时钟
F3日前、时间
F5安全范围 D2患者安全范围
P2 分析信号
危及病人信息
P3 产生警告信息
F2生理信号
F4警告信息
P1 接收信号
F2生理信号
E1 护士
P4 定时取样 生理信号
定时的生理信号 F6日志
P5 更新日志
D1患者日志
E1 护士
F6日志 F1要求报告
P6 产生病情报告
(3) 假设在1995年存储器字长为32位,一名程序员每天可 开发出30条指令,程序员的月平均工资为6000美元,重 复(1)、(2)题。
作业及解答(第1-2章)
(1)在1985年对计算机存储容量的需求,估计是
《软件工程导论》课后习题答案

作业及解答(第3章)
• 数据结构的描述 符 号
= +
含 义
x = a+b
举
例
被定义为 与 或
[...,...] 或 [...|...] { ... }或 m{...}n (...) “...” ..
23:59:38
x = [a , b],x = [a | b] 重复 x = {a}, x = 3{a}8 可选 x = (a) 基本数据元素 x = “a” 连结符 x = 1..9
P1 记录存款信息
P2 打印存单 F5存款信息 F3存单 E1 储户 F4利息
F5存款信息 D1存款信息 F7密码 F2取款单
F5存款信息 P3 核算密码
F4利息 F4利息 F6取款信息 P6 设置利率 P4 计算利息
P5 打印利息清单 F8储蓄利率
E2 业务员
23:59:38
F8储蓄利率
F8储蓄利率
23:59:38
重庆工学院计算机科学与工程学院 李梁(liliang@) 李梁
作业及解答( 作业及解答(第3章)
23:59:38
重庆工学院计算机科学与工程学院 李梁(liliang@) 李梁
作业及解答( 作业及解答(第3章)
• 3-6 复印机的工作过程大致如下:未接到复印 命令时处于闲置状态,一旦接到复印命令则进 入复印状态,完成一个复印命令规定的工作后 又回到闲置状态,等待下一个复印命令;如果 执行复印命令时发现没纸,则进入缺纸状态, 发出警告,等待装纸,装满纸后进入闲置状态, 准备接收复印命令;如果复印时发生卡纸故障, 则进入卡纸状态,发出警告等待维修人员来排 除故障,故障排除后回到闲置状态。 • 请用状态转换图描绘复印机的行为。
《软件工程导论》课后习题详细答案

《软件工程导论》课后习题详细答案第一章软件工程概论1.什么是软件危机?软件危机是指在运算机软件的开发和爱护过程中所遇到的一系列严峻咨询题。
这些咨询题表现在以下几个方面:(1)用户对开发出的软件专门难中意。
(2)软件产品的质量往往靠不住。
(3)一样软件专门难爱护。
(4)软件生产效率专门低。
(5)软件开发成本越来越大。
(6)软件成本与开发进度难以估量。
(7)软件技术的进展远远满足不了运算机应用的普及与深入的需要。
2.什么缘故会产生软件危机?(1) 开发人员方面,对软件产品缺乏正确认识,没有真正明白得软件产品是一个完整的配置组成。
造成开发中制定打算盲目、编程草率,不考虑爱护工作的必要性。
(2) 软件本身方面,关于运算机系统来讲,软件是逻辑部件,软件开发过程没有统一的、公认的方法论和规范指导,造成软件爱护困难。
(3) 专门是随着软件规模越来越大,复杂程度越来越高,原有软件开发方式效率不高、质量不能保证、成本过高、研制周期不易估量、爱护困难等一系列咨询题更为突出,技术的进展差不多远远不能适应社会需求。
3.如何样克服软件危机?(1) 充分吸取和借鉴人类长期以来从事各种工程项目中积存的行之有效的有效原理、概念、技术与方法,专门是吸取几十年来人类从事运算机硬件研究和开发的体会教训。
在开发软件的过程中努力作到良好的组织,严格的治理,相互友好的协作。
(2) 推广在实践中总结出来的开发软件的成功的技术和方法,并研究更好、更有效的技术和方法,尽快克服在运算机系统早期进展时期形成的一些错误概念和作法。
(3) 按照不同的应用领域,开发更好的软件工具并使用这些工具。
将软件开发各个时期使用的软件工具集合成一个整体,形成一个专门好的软件开发支环环境。
总之为了解决软件危机,既要有技术措施(方法和工具),又要有必要的组织治理措施。
4.构成软件项目的最终产品:应用程序、系统程序、面向用户的文档资料和面向开发者的文档资料。
5.什么是软件生存周期?软件生存周期是指从软件定义、开发、使用、爱护到剔除的全过程。
软件工程导论课后习题答案

软件工程导论(第5版)课后习题答案(总21页)--本页仅作为文档封面,使用时请直接删除即可----内页可以根据需求调整合适字体及大小--1-5 根据历史数据可以做出如下的假设:对计算机存储容量的需求大致按下面公式描述的趋势逐年增加:M=(Y-1960) 存储器的价格按下面公式描述的趋势逐年下降:P1=×(美分/位)如果计算机字长为16位,则存储器价格下降的趋势为:P2=×(美元/字)在上列公式中Y代表年份,M是存储容量(字数),P1和P2代表价格。
基于上述假设可以比较计算机硬件和软件成本的变化趋势。
要求计算:(1) 在1985年对计算机存储容量的需求估计是多少如果字长为16位,这个存储器的价格是多少(2) 假设在1985年一名程序员每天可开发出10条指令,程序员的平均工资是每月4000美元。
如果一条指令为一个字长,计算使存储器装满程序所需用的成本。
(3) 假设在1995年存储器字长为32位,一名程序员每天可开发出30条指令,程序员的月平均工资为6000美元,重复(1)、(2)题。
(1)在1985年对计算机存储容量的需求,估计是M=(1985-1960)=4474263(字)如果字长为16位,则这个存储器的价格是P=* 1985-1974*4474263=$5789(2)如果一条指令的长度为一个字,则使存储器装满程序共需4474263条指令。
在1985年一名程序员每天可开发出10条指令,如果每月有20个工作日,则每人每月可开发出10×20条指令。
为了开发出4474263条指令以装满存储器,需要的工作量是:4474263/200=22371(人月)程序员的月平均工资是4000美元,开发出4474263条指令的成本是22371*4000=¥(3)在1995年对存储容量的需求估计为:M=4080E0。
28(1995-1960)=(字)=如果字长为32位,则这个存储器的价格是:P=*32*(1995-1974)*=$7127如果一条指令为一个字长,则为使存储器装满程序共需73,577,679条指令。
软件工程导论课后习题答案

软件工程导论课后习题答案1. 什么是软件工程?软件工程是将系统化、规范化的方法应用于软件的开发、运行和维护的一门学科。
它包括软件需求分析、软件设计、软件开发、软件测试、软件维护等工作,旨在提高软件开发过程的效率和质量。
2. 软件生命周期是什么?软件生命周期是指软件从概念到退役的整个过程。
它通常包括以下阶段:需求分析、软件设计、编码、测试、部署、运维和退役。
3. 软件需求分析的目的是什么?软件需求分析的目的是理解客户和用户的需求,明确软件系统应具备的功能和性能要求,并以此为基础,为后续的设计、开发和测试工作提供准确的需求规格说明。
4. 软件设计的原则有哪些?•模块化原则:将软件划分为多个模块,每个模块负责一个特定的功能,以实现代码的复用和可维护性的提高。
•高内聚低耦合原则:模块内部的元素之间高度相关,而模块之间的依赖关系要尽量降低。
•封装原则:隐藏实现细节,将内部数据和操作通过接口封装起来,提供对外的访问方式。
•可读性原则:代码要易于阅读和理解,一致的命名和简洁的代码结构能提高代码的可读性。
•可测试性原则:设计要有良好的可测试性,便于进行单元测试和集成测试。
5. 软件开发过程中的常用模型有哪些?•瀑布模型:按照线性流程顺序依次完成需求分析、设计、开发、测试和部署等阶段。
•敏捷开发模型:采用迭代和增量的方式进行开发,快速响应需求变化。
•喷泉模型:将软件生命周期看做是连续不断的循环,在每个循环内快速迭代开发、测试和部署。
6. 软件测试的目的是什么?软件测试的目的是为了发现软件中的缺陷和错误,并尽早地修复这些问题,以确保软件的质量和可靠性。
通过测试,可以评估软件的功能是否满足需求,并验证软件是否在各种工作环境中正常工作。
7. 软件维护的类型有哪些?•纠错性维护:修复软件中的错误和缺陷。
•适应性维护:适应环境的变化,如操作系统升级、硬件设备更换等。
•完善性维护:根据用户的反馈和需求对软件进行改进和增强。
•预防性维护:对软件进行优化和调整,以提高性能和可维护性。
软件工程导论课后习题解答

第一章1-1 什么是软件危机?答:是指在计算机软件的开发和维护过程中所遇到的一系列严重问题。
1-3 什么是软件工程?答:是指导计算机软件开发和维护的一门工程学科。
1-4 简述结构化范型和面向对象范型的要点,并分析它们的优缺点。
答:目前使用得最广泛的软件工程方法学有2种:传统方法学:也称为生命周期方法学或结构化范型。
优点:把软件生命周期划分成若干个阶段,每个阶段的任务相对独立,而且比较简单,便于不同人员分工协作,从而降低了整个软件开发过程的困难程度。
缺点:当软件规模庞大时,或者对软件的需求是模糊的或会随着时间而变化的时候,开发出的软件往往不成功;而且维护起来仍然很困难。
面向对象方法学:优点:降低了软件产品的复杂性;提高了软件的可理解性;简化了软件的开发和维护工作;促进了软件重用。
1-5、根据历史数据可以做出如下的假设:对计算机存储容量的需求大致按下面公式描述的趋势逐年增加:M = 4080 e0.28(Y-1960)存储器的价格按下面公式描述的趋势逐年下降:P1 = 0.3×0.72Y-1974(美分/位)如果计算机字长为16位,则存储器价格下降的趋势为:P2 = 0.048×0.72Y-1974(美元/字)在上列公式中Y代表年份,M是存储容量(字数),P1和P2代表价格。
基于上述假设可以比较计算机硬件和软件成本的变化趋势。
要求计算:(1) 在1985年对计算机存储容量的需求估计是多少?如果字长为16位,这个存储器的价格是多少?(2) 假设在1985年一名程序员每天可开发出10条指令,程序员的平均工资是每月4000美元。
如果一条指令为一个字长,计算使存储器装满程序所需用的成本。
(3) 假设在1995年存储器字长为32位,一名程序员每天可开发出30条指令,程序员的月平均工资为6000美元,重复(1)、(2)题。
(1)在1985年对计算机存储容量的需求,估计是M= 4080 e0.28(1985-1960)= 4080 e7=4474263(字)如果字长为16位,则这个存储器的价格是P= 0.048 × 0.721995-1974× 73577679 = 5789(美元)(2)如果一条指令的长度为一个字,则使存储器装满程序共需4474263条指令。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
(2) 很明显一个大的没有被发现的风险问题,将会导致问题的发生,可能导致演化 的方法失去控制。 (3) 这种模型相对比较新,应用不广泛,其功效需要进一步的验证。
(3) 推广使用在实践中总结出来的开发软件的成功技术和方法
(4) 开发和使用更好的软件工具
三 、 简 述结构化范型 和面向对象范型的要点,并分析他们 的优缺点。
七、 什么是软件生 命周期模型 ?试比较瀑布 模型、快速 原型模型、 增量模型和螺 旋模型的优 缺 点 , 说明每种模型 的使用范围。 软件生命周期模型 是跨越整个 生存期的系 统开发、运作 和维护所实 施的全部过程 、活动和任 务的结构框架。
End sub 2、用面向数据流的方法设计下列系统的软件结构: (3)患者监护系统(需求见习题 2-4) 功能级数据流图:
E2 病人
F2生理信号
P2 分析信号
危及病人信息 F2生理信号
F5安全范围
D2患者安全范围
F2生理信号
D3生理信息
P7制定安 全范围
P1 接收信号
定时的生理信号
P5 更新日志
F2生理信号 定时的 生理信号
(2)使用附加的标志变量 flag,至少有两种方法可以把该程序改造为等价的结构化程序,下 图所示盒图描绘了两个等价的结构化程序。
(3)不使用 flag 把该程序改造为等价的结构化程序的方法如下图所示。
7、令 P 代表交易的总金额,Q 代表每股的售价,n 代表交易的股数。 判定表的每一列是一条计算规则。例如,第 1 列(规则 l)规定,当交易总金额 P 少于 1,
第一章
一 、 什 么是软件危机 ?它有哪些典型表现?为什么会出现 软件危机?
软件危机是指在 计算机软件 开发、使用与 维护过程中 遇到的一系益增长的 需求;如何 维护数量不断 增长的已有
软件。
软件危机的典型表现:
(1) 对软件开发成本和进度的估计常常很不准确。常常出现实际成本比估算成本高出一个数量
缺点:产品的先天 性不足,因 为开发者常 常需要做实现 上的折中, 可能采用不合 适的操作系 统或程序设计语言,以使原型能够尽快工作。
增量模型 优点: (1) 人员分配灵活,刚开始不用投入大量人力资源,当核心产品很受欢迎时,可增加人力实现 下一个增量。 (2) 当配备的人员不能在设定的期限内完成产品时,它提供了一种先推出核心产品的途径,这 样就可以先发布部分功能给客户,对客户起到镇静剂的作用。 缺点: (1) 至始至终开发者和客户纠缠在一起,直到完全版本出来。 (2) 适合于软件需求不明确、设计方案有一定风险的软件项目。
(4) 开发软件的效率非常重要,因此,软件工程的一个重要课题就是,寻求开发与维护软件的 更好更有效的方法和工具
(5) 和谐地合作是开发软件的关键
(6) 软件必须有效地支持它的用户
(7) 在软件工程领域中是由具有一种文化背景的人替具有另一种文化背景的人(完成一些工作)
消除软件危机的途径:
(1) 对计算机软件有一个正确的认识(软件≠程序) (2) 必须充分认识到软件开发不是某种个体劳动的神秘技巧,而应该是一种组织良好、管理严 密、各类人员协同配合、共同完成的工程项目
该模型适合于大型软件的开发
第二章 4.目前住 院病人主要由护士护理,这 样做不仅需要大量护士,而 且由于不能随时观察危重病 人的 病情变化,还 会延误抢救 时机。某医院 打算开发一 个以计算机 为中心的患者 监护系统, 请 写 出 问题定义,并 且分析开发这个系统的可行性。
医院对患者 监护系统的基本要求是随时接收每个 病人的生理信号 (脉搏、体温、血压、心 电图等 ),定时记录病人情况以 形成患者日志,当某个病人的生理 信号超出医生规定的安全范 围时 向值班护士发 出警告信息 ,此外,护士 在需要时还 可以要求系 统印出某个指 定病人的病 情报告。
P3 产生警告信息
F4警告信息
E1 护士
E3 时钟
F3日前、时间
P4 定时取样 生理信号
F6日志
E1 护士
软件结构图:
F6日志
F1要求报告
P6
产生病情报告
D1患者日志
生理信号
患者监护系 统
日志危机信息
定生时理生信理号信范号围
日志
日志 定时生理信号 危机信息 生理信号
生定理时信生理号信号
患者生理信
号获取
问题定义: 从问题陈述可知,本系统的数据源点是“病人”和“护士”,他们分别提供生理信号和要 求病情报告的信息。进一步分析问题陈述,从系统应该“定时记录病人情况以形成患者日志” 这项要求可以想到,还应该有一个提供日期和时间信息的“时钟”作为数据源点。 从问题陈述容易看出,本系统的数据终点是接收警告信息和病情报告的护士。 系统对病人生理信号的处理功能主要是“接收信号”、“分析信号”和“产生警告信息”。 此外,系统还应该具有“定时取样生理信号”、“更新日志”和“产生病情报告"的功能。 为了分析病人生理信号是否 超出了医生 规定的安全范 围,应该存 储“患者安 全范围”信 息。此外,定时记录病人生理信号所形成的“患者日志”,显然也是一个数据存储。
1993 年 IEEE 的定义:软件工程是:① 把系统的、规范的、可度量的途径应用于软件开 发、运行和维护过程,也就是把工程应用于软件;② 研究①中提到的途径。
软件工程的本质特征:
(1) 软件工程关注于大型程序(软件系统)的构造
(2) 软件工程的中心课题是分解问题,
控制复杂性
(3) 软件是经常变化的,开发过程中必须考虑软件将来可能的变化
电话号码 = [校内电话号码 | 校外电话号码]
校内电话号码 = 非零数字 + 3 位数字
校外电话号码 = [本市号码 | 外地号码]
本市号码 = 数字零 + 8 位数字
外地号码 = 数字零 + 3 位数字 + 8 位数字
非零数字 = [1|2|3|4|5|6|7|8|9]
数字零 = 0
3 位数字 = 3{数字}3
000 元,且每股售价 Q 低于 l4 元,且交易的股数 n 是 l00 的倍数时,给经纪人的手续费为: (1+0.05)×0.084P 第 16 列(规则 l6)表明,当交易总金额 P 超过 l0,000 元,且每股售价 Q 在 14 元到 25 元
请 用 状 态转换图描绘 复印机的行为。 从问题陈述可知,复印机的状态主要有“闲置”、“复印”、“缺纸”和“卡纸”。引起状态 转换的事件主要是“复印命令”、“完成复印命令”、“发现缺纸”、“装满纸”、“发生卡纸故障” 和“排除了卡纸故障”。状态转换图如下:
1、为每种类型的模块耦合举一个具体的例子。 (1) 非直接耦合—例如,两个模块没有直接关系(模块 1 和模块 2),模块独立性最强。
(2) 数据耦合—例如,下左图
数据耦合
特征耦合
(3) 特征耦合—例如,上右图
“住户情况”是一个数据结构,图中模块都与此数据结构有关。“计算水费”和“计算电
费”本无关,由于引用了此数据结构产生依赖关系,它们之间也是标记偶合。
(4) 控制耦合--模块 A 通过传送开关、标志、名字等控制信息,明显地控制选择模块 B 的功
许多难以想象的困难和难以解决的问题。
(6) 软件成本、软件维护费在计算机系统总成本中所占比例逐年上升。
(7) 开发生产率提高的速度远跟不上计算机应用普及的需求。
软件危机出现的原因:
(1) 来自软件自身的特点:是逻辑部件,缺乏可见性;规模庞大、复杂,修改、维护困难。 (2) 软件开发与维护的方法不当:忽视需求分析;认为软件开发等于程序编写;轻视软件维护。 (3) 供求矛盾将是一个永恒的主题:面对日益增长的软件需求,人们显得力不从心。 二 、 什 么是软件工程 ?它有哪些本质特征?怎样用软件工 程消除软件危机?
瀑布模型 优点: 它提供了一个模 板,这个模 板使得分析、 设计、编码 、测试和支 持的方法可 以在该模板 下有一个共同的指导。虽然有不少缺陷但比在软件开发中随意的状态要好得多。 缺点: (1) 实际的项目大部分情况难以按照该模型给出的顺序进行,而且这种模型的迭代是间接的, 这很容易由微小的变化而造成大的混乱。 (2) 经常情况下客户难以表达真正的需求,而这种模型却要求如此,这种模型是不欢迎具有二 义性问题存在的。 (3) 客户要等到开发周期的晚期才能看到程序运行的测试版本,而在这时发现大的错误时,可 能引起客户的惊慌,而后果也可能是灾难性的。 (4) 会经常在过程的开始和结束时碰到等待其他成员完成其所依赖的任务才能进行下去,有可 能花在等待的时间比开发的时间要长。称之为“堵塞状态”。 它是软件工程中应用最广泛的过程模型,在软件工程中占有肯定和重要的位置。 快速原型模型 在进行了基本需求分析之后,快速开发出产品的原型,然后基于这个原型,同客户沟通、 交流,更好地了解 客户需求, 不断修改这 个原型,到了 双方认可的 程度,再做详 细地分析、 设计和编程,最终开发出令客户满意的产品。 优点:使用户能够感受到实际的系统,使开发者能够快速地构造出系统的框架。
级、实际进度比计 划进度拖延 几个月甚至 几年的现象。 而为了赶进 度和节约成本 所采取的一
些权宜之计又往往损害了软件产品的质量。这些都降低了开发商的信誉,引起用户不满。
(2) 用户对已完成的软件不满意的现象时有发生。
(3) 软件产品的质量往往是靠不住的。 (4) 软件常常是不可维护的。 (5) 软件通常没有适当的文档资料。文档资料不全或不合格,必将给软件开发和维护工作带来
2、 怎 样 与用户有效的 沟通以获取用户的真实需求? (1) 初步需求获取,通过访谈与会议、问卷调查、观察用户工作流程等方法;