软件开发的方式有哪些

方式有:一、边做边改模型(Build-and-Fix Model);二、瀑布模型(Waterfall Model);三、快速原型模型(Rapid Prototype Model);四、增量模型(Incremental Model);五、螺旋模型(Spiral Model);六、喷泉模型(fountain model)。许多产品都是使用“边做边改”模型来开发的。

一、边做边改模型(Build-and-Fix Model)

许多产品都是使用“边做边改”模型来开发的。在这种模型中,既没有规格说明,也没有经过设计,软件随着客户的需要一次又一次地不断被修改。在这个模型中,开发人员拿到项目立即根据需求编写程序,调试通过后生成软件的第一个版本。在提供给用户使用后,如果程序出现错误,或者用户提出新的要求,开发人员重新修改代码,直到用户满意为止。这是一种类似作坊的开发方式,对编写几百行的小程序来说还不错,但这种方法对任何规模的开发来说都是不能令人满意的,其主要问题在于:缺少规划和设计环节,软件的结构随着不断的修改越来越糟,导致无法继续修改;忽略需求环节,给软件开发带来很大的风险;没有考虑测试和程序的可维护性,也没有任何文档,软件的维护十分困难。

二、瀑布模型(Waterfall Model)

1970年Winston Royce提出了著名的“瀑布模型”,直到80年代早期,它一直是唯一被广泛采用的软件开发模型。瀑布模型中,如图所示,将软件生命周期划分为制定计划、需求分析、软件设计、程序编写、软件测试和运行维护等六个基本活动,并且规定了它们自上而下、相互衔接的固定次序,如同瀑布流水,逐级下落。在瀑布模型中,软件开发的各项活动严格按照线性方式进行,当前活动接受上一项活动的工作结果,实施完成所需的工作内容。当前活动的工作结果需要进行验证,如果验证通过,则该结果作为下一项活动的输入,继续进行下一项活动,否则返回修改。瀑布模型强调文档的作用,并要求每个阶段都要仔细验证。但是,这种模型的线性过程太理想化,已不再适合现代的软件开发模式,几乎被业界抛弃,其主要问题在于:各个阶段的划分完全固定,阶段之间产生大量的文档,极大地增加了工作量;

由于开发模型是线性的,用户只有等到整个过程的末期才能见到开发成果,从而增加了开发的风险;早期的错误可能要等到开发后期的测试阶段才能发现,进而带来严重的后果。

我们应该认识到,“线性”是人们最容易掌握并能熟练应用的思想方法。当人们碰到一个复杂的“非 线性”问题时,总是千方百计地将其分解或转化为一系列简单的线性问题,然后逐个解决。一个软件系统的整体可能是复杂的,而单个子程序总是简单的,可以用线性的方式来实现,否则干活就太累了。线性是一种简洁,简洁就是美。当我们领会了线性的精神,就不要再呆板地套用线性模型的外表,而应该用活它。例如增量模 型实质就是分段的线性模型,螺旋模型则是接连的弯曲了的线性模型,在其它模型中也能够找到线性模型的影子。

三、快速原型模型(Rapid Prototype Model)

快速原型模型的第一步是建造一个快速原型,实现客户或未来的用户与系统的交互,用户或客户对原型进行评价,进一步细化待开发软件的需求。通过逐步调整原型使其满足客户的要求,开发人员可以确定客户的真正需求是什么;第二步则在第一步的基础上开发客户满意的软件产品。显然,快速原型方法可以克服瀑布模型的缺点,减少由于软件需求不明确带来的开发风险,具有显著的效果。快速原型的关键在于尽可能快速地建造出软件原型,一旦确定了客户的真正需求,所建造的原型将被丢弃。因此,原型系统的内部结构并不重要,重要的是必须迅速建立原型,随之迅速修改原型,以反映客户的需求。

四、增量模型(Incremental Model)

增量模型(Incremental Model)又称演化模型。与建造大厦相同,软件也是一步一步建造起来的。在增量模型中,软件被作为一系列的增量构件来设计、实现、集成和测试,每一个构件是由多种相互作用的模块所形成的提供特定功能的代码片段构成。增量模型在各个阶段并不交付一个可运行的完整产品,而是交付满足客户需求的一个子集的可运行产品。整个产品被分解成若干个构件,开发人员逐个构件地交付产品,这样做的好处是软件开发可以较好地适应变化,客户可以不断地看到所开发的软件,从而降低开发风险。但是,增量模型也存在以下缺陷:

由于各个构件是逐渐并入已有的软件体系结构中的,所以加入构件必须不破坏已构造好的系统部分,这需要软件具备开放式的体系结构。

在开发过程中,需求的变化是不可避免的。增量模型的灵活性可以使其适应这种变化的能力大大优于瀑布模型和快速原型模型,但也很容易退化为边做边改模型,从而是软件过程的控制失去整体性。在使用增量模型时,第一个增量往往是实现基本需求的核心产品。核心产品交付用户使用后,经过评价形成下一个增量的开发计划,它包括对核心产品的修改和一些新功能的发布。这个过程在每个增量发布后不断重复,直到产生最终的完善产品。例如,使用增量模型开发字处理软件。可以考虑,第一个增量发布基本的文件管理、编辑和文档生成功能,第二个增量发布更加完善的编辑和文档生成功能,第三个增量实现拼写和文法检查功能,第四个增量完成高级的页面布局功能。

五、螺旋模型(Spiral Model)

1988年,Barry Boehm正式发表了软件系统开发的“螺旋模型”,它将瀑布模型和快速原型模型结合起来,强调了其他模型所忽视的风险分析,特别适合于大型复杂的系统。如图所示,螺旋模型沿着螺线进行若干次迭代,图中的四个象限代表了以下活动:

制定计划:确定软件目标,选定实施方案,弄清项目开发的限制条件;

风险分析:分析评估所选方案,考虑如何识别和消除风险;

实施工程:实施软件开发和验证;

客户评估:评价开发工作,提出修正建议,制定下一步计划。螺旋模型由风险驱动,强调可选方案和约束条件从而支持软件的重用,有助于将软件质量作为特殊目标融入产品开发之中。但是,螺旋模型也有一定的限制条件,具体如下:

螺旋模型强调风险分析,但要求许多客户接受和相信这种分析,并做出相关反应是不容易的,因此,这种模型往往适应于内部的大规模软件开发。

如果执行风险分析将大大影响项目的利润,那么进行风险分析毫无意义,因此,螺旋模型只适合于大规模软件项目。

软件开发人员应该擅长寻找可能的风险,准确地分析风险,否则将会带来更大的风险。一个阶段首先是确定该阶段的目标,完成这些目标的选择方案及其约束条件,然后从风险角度分析方案的开发策略,努力排除各种潜在的风险,有时需要通过建造原型来完成。如果某些风险不能排除,该方案立即终止,否则启动下一个开发步骤。最后,评价该阶段的结果,并设计下一个阶段。

六、喷泉模型(fountain model)

喷泉模型(fountain model)(也称面向对象的生存期模型, OO模型)喷泉模型与传统的结构化生存期比较,具有更多的增量和迭代性质,生存期的各个阶段可以相互重叠和多次反复,而且在项目的整个生存期中还可以嵌入子生存期。就像水喷上去又可以落下来,可以落在中间,也可以落在最底部。

延伸阅读:

软件开发各模型比较

每个软件开发组织应该选择适合于该组织的软件开发模型,并且应该随着当前正在开发的特定产品特性而变化,以减小所选模型的缺点,充分利用其优点,下表列出了几种常见模型的优缺点。

瀑布模型:文档驱动 系统可能不满足客户的需求

快速原型模型:关注满足客户需求 可能导致系统设计差、效率低,难于维护

增量模型:开发早期反馈及时,易于维护 需要开放式体系结构,可能会导致效率低下

螺旋模型:风险驱动 风险分析人员需要有经验且经过充分训练

文章标题:软件开发的方式有哪些,发布者:Flawy,转载请注明出处:https://worktile.com/kb/p/52539

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
FlawyFlawy认证作者
上一篇 2023年5月23日
下一篇 2023年5月23日

相关推荐

  • 云原生与传统云计算的主要区别是什么

    云原生(Cloud Native)和传统云计算的差异主要在于它们各自在构建、部署和管理应用方面的方法和架构。云原生是指一套利用云计算的优势以实现更灵活、更可靠的软件开发和运维的技术与方法。相较于传统云计算,主要特征包括:1、微服务架构;2、容器化技术;3、动态管理;4、持续交付。传统云计算通常涉及虚…

    2023年11月23日
    59100
  • 什么是敏捷开发中的时间估算和时间盒

    敏捷开发中的时间估算和时间盒是项目管理中常用的工具和技术,用于规划、控制和管理项目的时间,有助于团队在敏捷开发中更好地预测、安排和跟踪工作的进展。详细介绍:1、时间估算,敏捷开发中用于预测和规划工作时间的过程,在时间估算中,团队根据项目的需求和任务的复杂性,评估完成每个任务所需的时间,可以帮助团队制定合理的计划和优先级,确保项目能够按时交付等等。

    2023年10月23日
    78800
  • DevOps与持续集成与持续交付的关系

    DevOps是一种文化和实践,旨在提高软件交付的速度和效率。1、 DevOps强调开发与运维团队的协同工作,提倡自动化流程,以便更加迅速、频繁地发布和部署软件。2、 持续集成(Continuous Integration, CI)和持续交付(Continuous Delivery, CD)则是Dev…

    2024年1月4日
    22900
  • 项目如何管理

    项目管理是确保项目按计划、预算内和质量标准成功完成的过程。关键成功因素包括明确的目标设定、持续的沟通、灵活性、风险管理、团队合作以及对时间和资源的有效管理。明确目标设定是基础,它涉及到对项目的范围、目标、可交付物和里程碑的精确定义,这有助于所有利益相关者对最终结果有一个统一的理解,并指导整个项目的方…

    2024年4月10日
    5400
  • 瀑布模型的特点是什么

    瀑布模型的特点包括:1、阶段间具有顺序性和依赖性;2、推迟实现的特点;3、质量保证的观点。瀑布模型是将软件生存周期的各项活动规定为按固定顺序而连接的若干阶段工作,形如瀑布流水,最终得到软件产品。 1. 阶段间具有顺序性和依赖性 阶段间具有顺序性和依赖性,这个特点有两重含义: (1)必须等前一阶段的工…

    2022年12月27日
    2.3K00
  • spring boot和SSM开发中有什么区别

    spring boot和SSM开发中的区别有:1、定义功能不同;2、对外提供服务不同;3、开发用处不同。开发Spring Boot时,能用比较便捷的注解来定义功能,而在spring mvc或ssm框架中,则需要用比较麻烦的xml配置文件来定义功能。 1、定义功能不同 开发Spring Boot时,能…

    2023年2月13日
    2.9K00
  • 软件项目管理系统功能模块有哪些

    功能模块有:一、项目进度管理;二、项目计划定制;三、项目成本控制;四、项目任务管理;五、项目数据分析。建立项目进度管理也被称为项目时间管理或项目的工期管理,是指在项目实施过程中,对各阶段的进展程度和项目最终完成的期限所进行的管理。 一、项目进度管理 建立项目进度管理也被称为项目时间管理或项目的工期管…

    2023年4月16日
    51200
  • Java中什么样的对象才能作为gcroot,gcroots有哪些呢

    在java技术体系里面,固定可作为GC Roots的对象包括以下几种:1、在虚拟机栈中引用的对象,例如各个线程被调用的方法堆栈中使用到的参数、局部变量、临时变量等;2、在方法区中类静态属性引用的对象,例如java类的引用类型静态变量。 一、Java中什么样的对象才能作为gcroot 在java技术体…

    2023年2月8日
    3.3K00
  • 协同文件怎么弄

    协同文件可以用以下工具弄:一、石墨文档;二、简道云;三、Coggle;四、金山文档;五、飞书。石墨文档是一款文档编辑软件,分享的文档支持多人实时协作。页面设计我清清爽爽,没有太多花里胡哨的设计。 一、石墨文档 石墨文档是一款文档编辑软件,分享的文档支持多人实时协作。页面设计我也比较喜欢,清清爽爽,没…

    2023年4月29日
    43000
  • Jira中如何批量编辑问题

    Jira中批量编辑问题是通过特定的操作来批量更新、变更或删除选定的多个问题。这些操作包括:1、搜索问题;2、选择操作;3、批量修改。在这众多步骤中,搜索问题的步骤尤为关键,因为有效的搜索是定位需要批量处理的问题的基础。使用高级搜索和Jira查询语言(JQL)能够精准地筛选出问题集。 在实施细节上,批…

    2024年1月3日
    62100

发表回复

登录后才能评论
注册PingCode 在线客服
站长微信
站长微信
电话联系

400-800-1024

工作日9:30-21:00在线

分享本页
返回顶部