- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
图1-4 软件开发增量模型 (2)增量模型的特点 增量模型的特点是引进了增量包的概念,无须等到所有需求都确定,只要某个需求的增量包确定即可进行开发。虽然某个增量包可能还需要进一步适应用户的需求并且更改,但只要这个增量包足够小,其影响对整个项目来说是并不大,在开发过程中是可以接受的。 (3)增量模型的优缺点 : 优点 人员分配灵活,项目开发开始时不用投入大量人力资源。如果核心产品很受欢迎,则可增加人力实现下一个增量。当配备的人员不能在设定的期限内完成产品时,它提供了一种先推出核心产品的途径。这样即可先发布部分功能给用户,帮助用户解决最为急需解决的问题。此外,增量能够有计划地管理技术风险。 缺点 由于各个构件是逐渐并入已有的软件体系结构中的,所以加入构件必须不破坏已构造好的系统部分,这需要软件具备开放式的体系结构;虽然增量模型的灵活性可以使其适应用户需求变化的能力大大优于瀑布模型和快速原型模型,但也很容易退化为边做边改模型,从而使软件过程的控制失去整体性;如果增量包之间存在相交的情况且未很好处理,则必须做全盘系统分析,这种模型将功能细化后分别开发的方法较适应于需求经常改变的软件开发过程。 9.软件开发的智能模型 (1)智能模型的基本原理 智能模型也称为“基于知识的软件开发模型”,它把瀑布模型和专家系统结合在一起,利用专家系统来帮助软件开发人员的工作。该模型应用基于规则的系统,采用归纳和推理机制,使维护在系统规格说明一级进行。 图1-5 软件开发智能模型 (2)智能模型的特点 智能模型所要解决的问题是特定领域的复杂问题,涉及大量的专业知识,而开发人员一般不是该领域的专家,他们对特定领域的熟悉需要一个过程,所以软件需求在初始阶段很难定义得很完整。因此,采用原型实现模型需要通过多次迭代来求精软件需求。 以上提到的三个基本原则,是系统方法论中处理复杂系统建设问题的三个基本原则,在处理实际中的复杂系统问题时,应根据具体情况结合上述三个基本原则确定解决问题的具体方法和策略。 20世纪60年代至70年代,亚当等人创造性地将系统工程的概念应用于大型软件系统的开发过程中。提成了自顶向下的、结构化分析和设计的开发方法。 亚当等人采用系统论方法开发软件,其核心是将整个软件的开发工作分为三个阶段,即问题的分析、系统设计和编程实现。 逐渐形成了软件生命周期开发方法。 2.结构化系统开发方法 所谓结构化系统开发方法(Structured system analysis and design)是结构化方法、系统方法和系统开发生命周期法的有机结合的软件开发方法。 该方法一经提出就得到系统开发人员的积极响应,并得到较为广泛地应用,是一种应用最为普遍和较为成熟的开发方法。 (1)结构化开发软件的基本思想 结构化开发软件的基本思想为:应用系统工程的思想和工程化的方法,根据尽力满足用户的需求的原则,结构化、模块化、自顶向下地对系统进行分析和设计。 (2)结构化系统开发方法的特点 结 构 化 系 统 开 发 方 法 特 点 高度重视调查工作 强调系统适应性 开发工作工程化 重视系统的前期开发工作,即 重视系统的调查、分析和设计 等工作 充分考虑组织对信息的需求及 对系统功能的要求 将系统自顶向下划分成若干子 系统(功能模块) 系统分析和设计由顶向下,而 系统的实施则由底向上进行 3.软件开发瀑布模型 (1)瀑布模型的基本概念 20世纪70年代,温斯顿?罗伊斯(Winston Royc⑤提出了软件生命周期的瀑布模型,较典型地刻画了软件生命周期的阶段划分,将软件生命周期划分为制定计划、需求分析、软件设计、程序编写、软件测试和运行维护等六个基本活动,并且规定了它们自上而下、相互衔接的固定次序,如同瀑布流水,逐级下落如图1-1所示 图1-1 软件开发瀑布模型 其过程是从上一项活动接收该项活动的工件(软件开发中的工件是指某项工作完成后所产生的成果)作为输入,利用这一输入实施该项活动应完成的内容给出该项活动的工作成果即工件,并作为输出传给下一项活动。同时评审该项活动的实施,若确认,则继续下一项活动;否则返回前面,甚至更前面的活动。 优点 为项目提供了按阶段划分的检查点,当前一阶段工作完成后,开发人员只需关注后续阶段,通常可在迭代模型中应用瀑布模型,以提升软件开发成功性。 缺点 在项目各个阶段之间极少有反馈,只有到一个阶段结束时,评审时才能发现上一阶段存在问题。同时也只有在项目生命周期的后期才能看到结果,通过过多的强制完成日期和里程碑来跟踪各个项目阶段性工作 (2)瀑布模型各阶段的主要工作 阶段 主要工作 应完成的文档 文档质量及控制要求 软件计划 调研用户需求及用户环境 可行性报告 项目初步开发计划 规范工作程序及编写文档 对可行性报告及项目初步论证 论证
原创力文档


文档评论(0)