系统架构15 - 软件工程(3)

软件过程模型

  • 瀑布模型
    • 特点
    • 缺点
  • 原型化模型
    • 特点
    • 两个阶段
    • 不同类型
    • 注意
  • 螺旋模型
  • V 模型
    • 特点
  • 增量模型
    • 特点
  • 喷泉模型
  • 基于构件的开发模型(CBSD)
  • 形式化方法模型
  • 敏捷模型
    • 特点
      • “适应性” (adaptive) 而非“预设性” (predictive)
      • “面向人的” (People-oriented) 而非“面向过程的” (Process-oriented)
    • 核心思想
    • 主要敏捷方法
      • 极限编程(XP)
        • 特点
      • 水晶系列方法
      • 并列争球法(Scrum)
      • 特征驱动开发方法(FDD)
        • 项目角色
        • 核心过程
  • 统一过程模型(RUP)
    • 生命周期阶段
      • 核心工作流
      • 循环中的阶段
    • 核心概念
    • 特点
      • 用例驱动
      • 以体系结构为中心
      • 迭代与增量

软件过程模型是一种规划和组织软件开发过程的方法。
过程模型通常由一系列阶段和任务组成,这些任务在软件开发的不同阶段都有特定的目标。每个阶段都有自己的任务和产出物,这些产出物构成了软件开发的不同部分,最终汇总成完整的软件产品。

瀑布模型

瀑布模型 (Waterfall Model) 是最早使用的软件过程模型之一,包含一系列活动。这些活动从一个阶段到另一个阶段逐次下降,它的工作流程在形式上很像瀑布,因此被称为瀑布模型。
瀑布模型

特点

  • 因果关系紧密相连,前一个阶段工作的输出结果,是后一个阶段工作的输入。
  • 每一个阶段都是建筑在前一个阶段正确实施的结果之上
  • 每一个阶段工作完成后都伴随着一个里程碑(一组检查条件),对该阶段的工作进行审查和确认

缺点

(1)软件需求的完整性、正确性等很难确定,甚至是不可能和不现实的。
(2)瀑布模型是一个严格串行化的过程模型,使得用户和软件项目负责人要相当长的时间才能得到一个可以看得见的软件系统。
(3)瀑布模型的基本原则是在每个阶段一次性地完全解决该阶段的工作,不会出现遗漏、错误等情况,而实际上这是不现实、不可能的。

原型化模型

原型模型 (Prototype Model) 又称快速原型。
由于瀑布型的缺点,人们借鉴建筑师、工程师建造原型的经验,提出了原型模型。
原型化模型

特点

创建快速原型,弄清当前需求。
适用于需求不明确的情况。

两个阶段

  1. 原型开发阶段。软件开发人员根据用户提出的软件系统的定义,快速地开发一个原型。该原型应该包含目标系统的关键问题和反映目标系统的大致面貌,展示目标系统的全部或部分功能、性能等。
  2. 目标软件开发阶段。在征求用户对原型的意见后对原型进行修改完善,确认软件系统的需求并达到一致的理解,进一步开发实际系统

不同类型

按照原型的作用不同,分为抛弃型原型和演化性原型
(1)抛弃型原型是将原型作为需求确认的手段,在需求确认结束后,原型就被抛弃不用,重新采用一个完整的瀑布模型进行开发。
(2)演化性原型是在需求确认结束后,不断补充和完善原型,直至
形成一个完整的产品。

注意

  • 用户对系统的认识模糊不清,无法准确回答目标系统的需求。
  • 要有一定的开发环境和工具支持。
  • 经过对原型的若干次修改,应收敛到目标范围内,否则可能会失败。
  • 对大型软件来说,原型可能非常复杂而难以快速形成,如果没有现成的原型模型,就不应考虑用原型法。

螺旋模型

螺旋模型 (Spiral Model) 是在快速原型的基础上扩展而成。也有人把螺旋模型归到快速原型,实际上,它是生命周期模型与原型模型的结合。
螺旋模型
这种模型把整个软件开发流程分成多个阶段,每一个阶段都由4部分组成:
(1)目标设定。为该项目进行需求分析,定义和确定这一个阶段的专门目标,指定对过程和产品的约束,并且制订详细的管理计划。
(2)风险分析。对可选方案进行风险识别和详细分析,制定解决办法,采取有效措施避免这些风险。
(3)开发和有效性验证。风险评估后,可以为系统选择开发模型,并且进行原型开发,即开发软件产品。
(4)评审。对项目进行评审,以确定是否需要进入螺旋线的下一次回路,如果决定继续,就要制订下一阶段计划。

该模型支持大型软件开发,适用于面向规格说明、面向过程和面向对象的软件开发方法,也适用于几种开发方法的组合。

V 模型

从整体上看,V模型就是一个V字结构。
由左右两边组成,如下图。
V模型

特点

  • 单元测试的主要目的是针对编码过程中可能存在的各种错误;
  • 集成测试主要针对详细设计中可能存在的问题;
  • 系统测试主要针对概要设计,检查系统作为一个整体是否有效得到运行;
  • 验收测试通常由业务或专家或用户来进行,以确认产品能真正符合用户业务上的需要。
  • V模型适用于需求明确并且需求变更不频繁的情形。

增量模型

首先开发核心模块功能,而后与用户确认,之后再开发次核心模块的功能。
即,每次开发一部分功能,并与用户确认,最终完成项目开发,优先级最高的服务最先交付。
增量模型

特点

但由于并不是从系统整体角度规划各个模块,所以并不利于模块划分。
难点在于如何将用户需求划分为多个增量。
与原型不同的是,增量模型的每一次增量版本都可以作为独立可操作的产品;而原型的构造一般是为了演示。

喷泉模型

是一种以用户需求作为动力,以对象作为驱动的模型,适合于面向对象开发方法。

基于构件的开发模型(CBSD)

也称为快速开发模型
主要是利用预先包装的构件来构造应用系统。
构件可以是组织内部开发的构件,也可以是商品化成品软件构件
特点是增强了复用性
在开发过程中,会构建一个构件库,供其它系统复用,因此可以提高可靠性,节省时间和成本

形式化方法模型

建立在严格数学基础上的一种软件开发方法。
主要活动是生成计算机软件形式化的数学规格说明

敏捷模型

软件开发在20世纪90年代受到两个大的因素影响:

  1. 对内,面向对象编程开始取代面向过程编程;
  2. 对外,互联网泡沫导致快速投向市场以及公司的快速发展成为关键商业因素。

快速变化的需求需要短的产品交付周期,这与传统软件开发流程并不兼容。
2001年2月,17位著名的软件开发专家举行了一次敏捷方法发起者和实践者的聚会。在这次会议上,正式提出了Agile (敏捷)的概念。

特点

敏捷型方法主要有两个特点,这也是其区别于其他方法——尤其是计划驱动或重型开发方法——的最主要的特征

“适应性” (adaptive) 而非“预设性” (predictive)

软件开发不同于传统工程——如土木工程等——无法将设计和实施分离开来
一些设计错误只能在编码和测试时才能发现,根本无法做出一个交给程序员就能直接编码的软件设计。
软件需求的不稳定,导致软件过程的不可预测
但是,必须对这样的过程进行监控,以使得整个过程能向期望的目标前进。
敏捷方法使用反馈机制对不可预测过程进行控制。

“面向人的” (People-oriented) 而非“面向过程的” (Process-oriented)

  • 敏捷开发过程要求开发人员必须有权做技术方面的所有决定。开发人员和管理人员在一个软件项目的领导方面有同等的地位,共同对整个开发过程负责。
  • 敏捷方法特别强调开发中相关人员之间的信息交流。项目的需求是在不断变化的,管理人员之间、开发人员之间以及管理人员和开发人员之间,都必须不断地了解这些变化,对这些变化做出反应,并实施在随后的开发过程中。
  • 敏捷方法还特别提倡直接的面对面交流。一般都按照高内聚、低耦合的原则将项目划分为若干小组,以增加沟通,提高敏捷性及应变能力

核心思想

  1. 敏捷方法是适应型,而非可预测型。与传统方法不同,敏捷方法拥抱变化,也可以说它的初衷就是适应变化的需求,利用变化来发展,甚至改变自己,最后完善自己。
  2. 敏捷方法是以人为本,而非以过程为本。强调充分发挥人的特性,不去限制它。并且软件开发在无过程控制和过于严格烦琐的过程控制中取得一种平衡,以保证软件的质量。
  3. 迭代增量式的开发过程。敏捷方法以原型开发思想为基础,采用迭代增量式开发,发行版本小型化。它根据客户需求的优先级和开发风险,制订版本发行计划,每一发行版都是在前一成功发行版的基础上进行功能需求扩充,最后满足客户的所有功能需求。

主要敏捷方法

极限编程(XP)

极限编程 (Extreme Programming,XP)。
在所有的敏捷型方法中, XP是最引人瞩目的。
极限编程是一个轻量级的、灵巧的软件开发方法;同时它也是一个非常严谨和周密的方法。
它的基础和价值观是交流、朴素、反馈和勇气,即任何一个软件项目都可以从4个方面入手进行改善:加强交流;从简单做起;寻求反馈;勇于实事求是。

特点
  1. XP是一种近螺旋式的开发方法,它将复杂的开发过程分解为一个个相对比较简单的小周期;通过积极的交流、反馈以及其他一系列的方法,开发人员和客户可以非常清楚开发进度、变化、待解决的问题和潜在的困难等,并根据实际情况及时地调整开发过程;
  2. XP提倡测试先行,目的是将以后出现BUG的几率降至最低。

水晶系列方法

水晶系列方法(Crystal)与XP方法一样,都有以人为中心的理念,但在实践上有所不同。
其目的是发展一种提倡“机动性的”方法,包含具有共性的核心元素,每个都含有独特的角色、过程模式、工作产品和实践。
Crystal 家族实际上是一组经过证明、对不同类型项目非常有效的敏捷过程,它的发明使得敏捷团队可以根据其项目和环境选择最合适的 Crystal 家族成员。

并列争球法(Scrum)

并列争球法(Scrum)侧重于项目管理
Scrum是迭代式增量软件开发过程,通常用于敏捷软件开发。 Scrum包括了一系列实践和预定义角色的过程骨架(是一种流程、计划、模式,用于有效率地开发软件)。
在Scrum 中,使用产品 Backlog 来管理产品的需求
产品 Backlog 是一个按照商业价值排序的需求列表。
根据 Backlog 的内容,将整个开发过程被分为若干个短的迭代周期 (Sprint)。
在 Sprint 中,Scrum 团队从产品 Backlog 中挑选最高优先级的需求组成 Sprint backlog。
在每个迭代结束时, Scrum 团队将递交潜在可交付的产品增量
所有 Sprint 结束时,团队提交最终的软件产品

特征驱动开发方法(FDD)

特征驱动开发方法 (Feature Driven Development,FDD) 是一个迭代的开发模型。 FDD认为有效的软件开发需要3个要素:人、过程和技术

项目角色

FDD定义了6种关键的项目角色
(1)项目经理
(2)首席架构设计师
(3)开发经理
(4)主程序员
(5)程序员
(6)领域专家。
根据项目大小,部分角色可以重复。

核心过程

(1)开发整体对象模型
(2)构造特征列表
(3)计划特征开发
(4)特征设计
(5)特征构建。
其中,计划特征开发根据构造出的特征列表、特征间的依赖关系进行计划,设计出包含特征设计和特征构建过程组成的多次迭代

统一过程模型(RUP)

软件统一过程 (Rational Unified Process, RUP) 描述了如何有效地利用商业的、可靠的方法开发和部署软件,是一种重量级过程
RUP类似一个在线的指导者,它可以为所有方面和层次的程序开发提供指导方针、模版以及事例支持

生命周期阶段

核心工作流

RUP 软件开发生命周期是一个二维的软件开发模型,RUP 中有9个核心工作流,具体如下。

  • 业务建模 (Business Modeling):理解待开发系统所在的机构及其商业运作,确保所有参与人员对待开发系统所在的机构有共同的认识,评估待开发系统对所在机构的影响。
  • 需求(Requirements):定义系统功能及用户界面,使客户知道系统的功能,使开发人员理解系统的需求,为项目预算及计划提供基础。
  • 分析与设计 (Analysis & Dcsign):把需求分析的结果转化为分析与设计模型
  • 实现 (Implementation):把设计模型转换为实现结果,对开发的代码做单元测试,将不同实现人员开发的模块集成为可执行系统。
  • 测试 (Test):检查各子系统之间的交互、集成,验证所有需求是否均被正确实现,对发现的软件质量上的缺陷进行归档,对软件质量提出改进建议。
  • 部署 (Deployment):打包、分发、安装软件,升级旧系统;培训用户及销售人员,并提供技术支持。
  • 配置与变更管理 (Configuration & Change Management):跟踪并维护系统开发过程中产生的所有制品的完整性和一致性
  • 项目管理 (Project Management):为软件开发项目提供计划、人员分配、执行、监控等方面的指导,为风险管理提供框架。
  • 环境 (Environment):为软件开发机构提供软件开发环境,即提供过程管理和工具的支持。

表示核心工作流的术语 Discipline,中文意义较多。根据RUP的定义,Discipline是相关活动的集合,这些活动都和项目的某一个方面有关,如这些活动都是和业务建模相关的,或者都是和需求相关的,或者都是和分析设计相关的,等等。

循环中的阶段

RUP 把软件开发生命周期划分为多个循环 (Cycle),每个循环生成产品的一个新的版本,每个循环依次由4个连续的阶段 (Phase) 组成,每个阶段完成确定的任务

  • 初始 (inception) 阶段:定义最终产品视图和业务模型,并确定系统范围。
  • 细化 (elaboration) 阶段:设计及确定系统的体系结构,制订工作计划及资源要求。
  • 构造 (construction) 阶段:构造产品并继续演进需求、体系结构、计划直至产品提交。
  • 移交 (transition) 阶段:把产品提交给用户使用。

每一个阶段都由一个或多个连续的迭代 (Iteration) 组成。
迭代并不是重复地做相同的事,而是针对不同用例的细化和实现
每一个迭代都是一个完整的开发过程,它需要项目经理根据当前迭代所处的阶段以及上次迭代的结果,适当地对核心工作流中的行为进行裁剪。
在每个阶段结束前有一个里程碑 (Milestone) 评估该阶段的工作。如果未能通过该里程碑的评估,则决策者应该做出决定,是取消该项目还是继续做该阶段的工作。

核心概念

RUP 中定义了如下一些核心概念,理解这些概念对于理解RUP很有帮助。

  • 角色 (Role):Who 的问题。角色描述某个人或一个小组的行为与职责。 RUP预先定义了很多角色,如体系结构师 (Architect)、 设计人员 (Designer)、 实现人员(Implementer)、 测试员 (tester) 和配置管理人员 (Configuration Manager) 等,并对每一个角色的工作和职责都做了详尽的说明。
  • 活动 (Activity):How 的问题。活动是一个有明确目的的独立工作单元。
  • 制品(Artifact):What 的问题。制品是活动生成、创建或修改的一段信息。也有些书把 Artifact 翻译为产品、工件等,和制品的意思差不多。
  • 工作流 (Workflow):When 的问题。工作流描述了一个有意义的连续的活动序列,每个工作流产生一些有价值的产品,并显示了角色之间的关系。

RUP 2003对这些概念有比较详细的解释,并用类图描述了这些概念之间的关系,除了上述这4个核心概念外,还有其他一些基本概念,如工具教程 (ToolMentor)、 检查点 (Checkpoints)、 模板 (Template) 和报告 (Report) 等。

特点

RUP 是用例驱动的、以体系结构为中心的、迭代和增量的软件开发过程

用例驱动

RUP中的开发活动是用例驱动的,即需求分析、设计、实现和测试等活动都是用例驱动的。

以体系结构为中心

RUP中的开发活动是围绕体系结构展开的
软件体系结构的设计和代码设计无关,也不依赖于具体的程序设计语言。
软件体系结构是软件设计过程中的一个层次,这一层次超越计算过程中的算法设计和数据结构设计。
体系结构层次的设计问题包括系统的总体组织和全局控制、通信协议、同步、数据存取、给设计元素分配功能、设计元素的组织、物理分布、系统的伸缩性和性能等。
对于一个软件系统,不同人员所关心的内容是不一样的。
因此,软件的体系结构是一个多维的结构,也就是说,会采用**多个视图 **(View) 来描述软件体系结构。
RUP采用“4+1”视图模型来描述软件系统的体系结构,如下图所示。
4+1视图模型

迭代与增量

RUP强调采用迭代和增量的方式来开发软件,把整个项目开发分为多个迭代过程
在每次迭代中,只考虑系统的一部分需求,进行分析、设计、实现、测试和部署等过程。
每次迭代是在已完成部分的基础上进行的,每次增加一些新的功能实现。
以此进行下去,直至最后项目的完成。
软件开发采用迭代和增量的方式有以下几种优点
(1)在软件开发的早期就可以对关键的、影响大的风险进行处理。
(2)可以提出一个软件体系结构来指导开发。
(3)可以更好地处理不可避免的需求变更。
(4)可以较早得到一个可运行的系统,鼓舞发团队的士气,增强项目成功的信心。
(5)为开发人员提供一个能更有效工作的开发过程。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/245473.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

02-Redis持久化、主从与哨兵架构详解

文章目录 Redis持久化RDB快照(snapshot)bgsave的写时复制(COW)机制AOF(append-only file)AOF重写RDB 和 AOF ,我应该用哪一个? Redis 4.0 混合持久化Redis数据备份策略: Redis主从架构redis主从…

2023年我国民用无人机产业规模超过1200亿元,低空经济时代来临

2023年我国民用无人机产业规模超过1200亿元,低空经济时代来临 根据最新数据显示,2023年中国的民用无人机产业规模已经超过了1200亿元,稳居全球榜首。预计到2025年,这个数字将突破2000亿元,届时低空经济对国民经济的综…

STC89C51单片机

本文为博主 日月同辉,与我共生,csdn原创首发。希望看完后能对你有所帮助,不足之处请指正!一起交流学习,共同进步! > 发布人:日月同辉,与我共生_单片机-CSDN博客 > 欢迎你为独创博主日月同…

ChatGPT 全域调教高手:成为人工智能交流专家

随着人工智能的快速发展,ChatGPT作为一种强大的文本生成模型,在各行各业中越来越受到重视和应用。想要利用ChatGPT实现更加智能、自然的交流,成为 ChatGPT 全域调教高手吗?本文将为您介绍如何通过优化ChatGPT的训练方法&#xff0…

【c语言】扫雷

前言: 扫雷是一款经典的单人益智游戏,它的目标是在一个方格矩阵中找出所有的地雷,而不触碰到任何一颗地雷。在计算机编程领域,扫雷也是一个非常受欢迎的项目,因为它涉及到许多重要的编程概念,如数组、循环…

Axios取消请求:AbortController

AbortController AbortController() 构造函数创建了一个新的 AbortController 实例。MDN官网给出了一个利用AbortController取消下载视频的例子。 核心逻辑是:利用AbortController接口的只读属性signal标记fetch请求;然后在需要取消请求的时候&#xff0…

php二次开发股票系统代码:腾讯股票数据接口地址、批量获取股票信息、转换为腾讯接口指定的股票格式

1、腾讯股票数据控制器 <?php namespace app\index\controller;use think\Model; use think\Db;const BASE_URL http://aaaaaa.aaaaa.com; //腾讯数据地址class TencentStocks extends Home { //里面具体的方法 }2、请求接口返回内容 function juhecurl($url, $params f…

蓝桥杯备战——2.矩阵键盘

1.分析原理图 由上图可以看到若J5跳线帽接地&#xff0c;就S4~S7就可以当做四路独立按键&#xff0c;若接到P44&#xff0c;则就是4*4的矩阵键盘。 2.独立按键处理 相对传统的按键延时消抖方案&#xff0c;这里我采用更高效&#xff0c;更经典&#xff0c;更偏向产品级应用的…

[bat]基于msg的弹窗提示

一、方案 1、定时自动消失的弹窗 代码&#xff1a; echo off echo method 1 msg * /time:5 "123456" REM echo method 2 REM msg * "123456"pause 效果&#xff1a; 立即弹窗在5秒后消失。 2、一直存在的弹窗 源码&#xff1a; echo off REM echo m…

Python基础之数据库操作

一、安装第三方库PyMySQL 1、在PyCharm中通过 【File】-【setting】-【Python Interpreter】搜索 PyMySQL进行安装 2、通过PyCharm中的 Terminal 命令行 输入: pip install PyMySQL 注&#xff1a;通过pip安装&#xff0c;可能会提示需要更新pip&#xff0c;这时可执行&#…

15- OpenCV:模板匹配(cv::matchTemplate)

目录 1、模板匹配介绍 2、cv::matchTemplate 3、模板匹配的方法&#xff08;算法&#xff09; 4、代码演示 1、模板匹配介绍 模板匹配就是在整个图像区域发现与给定子图像匹配的小块区域。 它可以在一幅图像中寻找与给定模板最相似的部分。 模板匹配的步骤&#xff1a; &a…

Gradle学习笔记:Gradle的简介、下载与安装

文章目录 一、什么是Gradle二、为什么选择Gradle三、下载并安装Gradle四、Gradle的bin目录添加到环境变量五、测试Gradle是否安装正常 一、什么是Gradle Gradle是一个开源构建自动化工具&#xff0c;专为大型项目设计。它基于DSL&#xff08;领域特定语言&#xff09;编写&…

SpringCloud(二)

Spring Cloud 文章目录 Spring Cloud任务三&#xff1a;Spring Cloud与微服务架构1.Spring Cloud课程内容介绍2.单体应用架构2.1 互联网应用架构演进2.2 单体应用架构 3.垂直应用架构4.SOA应用架构5.微服务应用架构介绍6.微服务架构核心思想及优缺点7.微服务架构的核心概念8.Sp…

如何使用Jellyfin+cpolar搭建私人影音平台实现无公网ip远程访问

文章目录 1. 前言2. Jellyfin服务网站搭建2.1. Jellyfin下载和安装2.2. Jellyfin网页测试 3.本地网页发布3.1 cpolar的安装和注册3.2 Cpolar云端设置3.3 Cpolar本地设置 4.公网访问测试5. 结语 1. 前言 随着移动智能设备的普及&#xff0c;各种各样的使用需求也被开发出来&…

3d gaussian splatting介绍整理

3D 高斯分布是用于实时辐射场渲染的 3D 高斯分布中描述的一种光栅化技术&#xff0c;它允许实时渲染从小图像样本中学习到的逼真场景。 paper github 本文翻译整理自&#xff1a; blog: Introduction to 3D Gaussian Splatting DDPMs - Part 2 给出一些2D图片&#xff0c;用…

[实战]加密传输数据解密

前言 下面将分享一些实际的渗透测试经验&#xff0c;帮助你应对在测试中遇到的数据包内容加密的情况。我们将以实战为主&#xff0c;技巧为辅&#xff0c;进入逆向的大门。 技巧 开局先讲一下技巧&#xff0c;掌握好了技巧&#xff0c;方便逆向的时候可以更加快速的找到关键…

【iOS ARKit】人脸检测追踪基础

在计算机人工智能&#xff08;Artificial Inteligence,AI&#xff09;物体检测识别领域&#xff0c;最先研究的是人脸检测识别&#xff0c;目前技术发展最成熟的也是人脸检测识别。人脸检测识别已经广泛应用于安防、机场、车站、闸机、人流控制、安全支付等众多社会领域&#x…

Linux 一键部署grafana

grafana 前言 Grafana 是一款开源的数据可视化和监控仪表盘工具。它提供了丰富的数据查询、可视化和报警功能,可用于实时监控、数据分析和故障排除等领域。 通过 Grafana,您可以连接到各种不同的数据源,包括时序数据库(如 Prometheus、InfluxDB)和关系型数据库(如 MySQ…

UE创建数据资产 UDataAsset

UE创建数据资产 需要一个继承自UDataAsset的子类 在编辑器里创建后的效果 如果在子类中写多个集合 和 其它数据 所以数据资产在我觉得只是该子类的一个实例对象

C#用DateAndTime.DateDiff方法和TimeSpan分别计算时间间隔

目录 一、计算时间间隔的方法 1.用DateAndTime.DateDiff方法计算时间间隔 2.使用TimeSpan获取日期时间间隔 二、实例 1.示例一&#xff1a;用DateAndTime.DateDiff方法计算时间间隔 2.示例二&#xff1a;使用TimeSpan获取日期时间间隔 一、计算时间间隔的方法 1.用Date…