文章目录

  • 一、软件工程的定义
    • 1、Fritz Bauer在NATO上给出的定义
    • 2、Barry Boehm
    • 3、IEEE在软件工程术语汇编中的定义
  • 二、软件工程的层次
    • 1、软件工程三个要素
    • 2、软件工程的层次——图解
    • 3、软件工程的层次——逐一分析
  • 三、软件过程的三个阶段
    • 1、定义阶段——“做什么”
    • 2、开发阶段——“如何做”
    • 3、支持阶段——“变化”
  • 四、软件过程框架
    • 1、引例——煮蛋的启示
    • 2、软件工程的过程定义
    • 3、软件过程框架
  • 五、CMM
    • 1、基础知识
    • 2、CMM的级别
  • 六、软件过程模型
    • 1、软件过程模型概述
    • 2、软件过程模型分类
    • 3、传统的软件过程模型
      • (1)线性顺序模型(瀑布模型)
      • (2)V模型
      • (3)原型实现模型
      • (4)RAD模型
      • (5)增量模型
      • (6)螺旋模型
      • (7)形式化方法模型
    • 4、敏捷视角下的过程模型
      • (1)什么是敏捷
      • (2)敏捷团队必须具备的特点
      • (3)几种重要的敏捷过程模型
        • ①极限编程(XP)
        • ②自适应软件开发(ASD)
        • ③动态系统开发方法(DSDM)
        • ④Scrum(橄榄球模型)
        • ⑤Crystal
        • ⑥特征驱动开发(FDD)
        • ⑦敏捷建模(AM)
  • 写在最后

一、软件工程的定义

1968年在NATO会议上,首次提出“软件工程”这个术语。但软件工程一直以来都缺乏一个统一的定义,有很多学者、组织机构都分别给出了自己认可的定义。以下给出三种常用的定义

1、Fritz Bauer在NATO上给出的定义

The establishment and use of sound engineering principles in order to obtain economically software that is reliable and works on real machines.

建立并使用完善的工程化原则,以较经济的手段获得能在实际机器上有效运行的可靠软件的一系列方法。

2、Barry Boehm

Software engineering is that form of engineering that applies the principles of computer science and mathematics to achieving cost-effective solutions to software problems.

软件工程就是应用计算机科学和数学的原理,来为软件问题提供经济高效的解决方案。

通俗点来说:①运用现代科学技术知识来设计并构造计算机程序;开发、运行和维护这些程序所必需的相关文件资料。

3、IEEE在软件工程术语汇编中的定义

The application of a systematic,disciplined,quantifiable approach to the development,operation,and maintenance of software.

将系统化的、严格约束的、可量化的方法应用于软件的开发、运行和维护,即将工程化应用于软件。

二、软件工程的层次

软件工程是一种层次化的技术,支持软件工程的根基就在于对质量的关注

1、软件工程三个要素

过程、方法、工具

2、软件工程的层次——图解

3、软件工程的层次——逐一分析

(1)质量焦点(a quality focus)

软件工程的根基,任何工程方法都必须以有组织的质量承诺为基础

(2)过程(process)

是软件工程的基础,定义了一组关键过程区域框架,包括*工程产品的产生*,里程碑的建立等等

(3)方法(methods)

提供了建造软件在技术上需要“如何做”,包括需求分析(analysis)、设计(design)、编码(coding)、测试(testing)和支持(backing)

(4)工具(tools)

对过程和方法提供了自动或半自动的支持

E.g. CASE工具(计算机辅助软件工程):集成硬件、软件和数据库而创建的软件工程环境,类似于硬件的CAD(计算机辅助设计)/CAE(计算机辅助工程)

三、软件过程的三个阶段

1、定义阶段——“做什么”

1定义:系统和软件的关键需求被标识

2应用场景系统和信息工程;软件项目计划;需求分析

2、开发阶段——“如何做”

1定义:定义数据结构、体系结构、过程细节、界面表示、算法和测试如何执行

2应用场景软件设计;代码生成;软件测试

3、支持阶段——“变化”

1定义纠正错误;随着软件环境的演化而要求的适应性修改;用户需求的变化而带来的增强型修改

2应用场景纠错性维护(校正式);适应性维护;完善性维护;预防性维护

下面用一张图了解软件过程的三个阶段

四、软件过程框架

1、引例——煮蛋的启示

很久以前,中国人煮蛋方式与德国人煮蛋方式的不同。

中国人:先找一个锅,倒进水,再把蛋放进去,整个过程需要10~20min。

德国人:先找一个锅,倒进水,再把蛋放进去,在容器的下方焊接一个托盘,再将锅放到托盘上去烧开,如此,仅用1min就把水烧开,之后再用火继续煮了3min,关火;再用余热继续煮了3min;煮熟后丢到冷水里面3min;最后他用10min时间把蛋煮熟。

从以上分析来看,德国人煮蛋更讲究过程,不同的过程会导致不一样的结果。研究表明,德国人煮蛋的方式有以下几点好处:①更省水;②更省热能;③煮蛋所花时间更少;④利用余热煮3min,这个时候蛋的营养价值更高;⑤用凉水泡了3min,蛋壳更容易拨开。

2、软件工程的过程定义

(1)过程(process):一组有序的任务,每个任务由一些步骤组成,每个步骤涉及到活动、约束及产品

(2)广义上,软件开发的每一个阶段都可看成是一个过程。

(3)简言之,过程就是一个步骤、一个路线图,帮助创建高质量的软件。

3、软件过程框架

先用一张图简单了解软件过程框架:


(1)通用过程框架活动

  • 沟通
  • 策划
  • 建模
  • 构建
  • 部署

(2)普适性活动

  • 软件项目跟踪和控制
  • 正式的技术评审
  • 软件质量保证
  • 软件配置管理
  • 文档的准备和产生
  • 可复用管理
  • 测度
  • 风险管理

五、CMM

1、基础知识

1)20世纪90年代(CMU/SEI)提出能力成熟度模型(Capability Maturity Model,CMM)

2)CMM定义了当一个组织达到不同的过程成熟度时应该具有的软件工程能力

3)CMM是一种衡量软件开发能力成熟度的标准

4)CMM模型提供了衡量一个公司软件工程实践的整体有效性的方法,且建立了五级的过程成熟度级别

2、CMM的级别

(1)第一级:初始级(initial)

①定义:软件过程是定义的偶然的,有时甚至是混乱的。几乎没有过程定义,成功完全取决于个人能力

②特点:不可预测并且缺乏控制。

(2)第二级:可重复级(repeatable)

①定义:建立了基本的项目管理过程,能够跟踪费用、进度和功能。有适当的必要的过程规范,可以重复以前类似项目的成功。

②特点:可重复以前的主要经验。

③关键过程区域:需求管理;软件项目计划;软件项目跟踪和监督;软件子合同管理;软件质量保证;软件配置管理。

(3)第三级:定义级(defined)

①定义:企业的软件过程已经文档化、标准化并与整个组织的软件过程相集成。所有项目都使用统一的、文档化的、组织过程认可的版本来开发和维护软件。包含第二级的所有特征。

②特点:过程被描述,并得到良好理解。

③关键过程区域:组织过程定义;组织过程焦点;培训大纲;集成软件管理;软件质量保证;软件配置管理。

(4)第四级:管理级(managed)

①定义:软件过程和产品质量的详细数据被收集,通过这些度量数据,软件过程和产品能够被定量地理解和控制。包含第三级的所有特征。

②特点:过程被测量并受控。

③关键过程区域:定量的过程管理;软件质量管理。

(5)第五级:优化级(optimizing)

①定义:通过定量反馈进行不断的过程改进,这些反馈来自于过程或通过试验新的想法技术而得到。包含第四级所有特征。

②特点:关注过程改进。

③关键过程区域:缺陷预防;技术变更管理;过程变更管理。

六、软件过程模型

1、软件过程模型概述

软件过程模型是软件开发全部过程、活动和任务的结构框架。软件过程模型不是一种具体模型,是一种开发策略,包含过程、方法和工具三个层次以及一般性阶段,常称为:软件开发模型;软件生存期模型;软件工程范型。

2、软件过程模型分类

(1)传统的软件过程模型(7种)

详细内容见以下第3点

(2)敏捷视角下的过程模型(7种)

详细内容见以下第4点

3、传统的软件过程模型

(1)线性顺序模型(瀑布模型)

①图解

②存在问题

  • 实际项目很少按照该模型给出的顺序执行
  • 客户常常难以清楚地给出需求
  • 客户必须有耐心,运行版要到开发晚期才能得到
  • 导致“阻塞状态”,常发生在开始和结束时

(2)V模型

①图解


②特点——强调反馈,不将问题留到下一步

Verification验证:每个活动保证能正确运行。

Validation确认:针对需求而言,符合需求规格的定义。

(3)原型实现模型

①定义

原型是一个可迭代的/可重复的(循环)过程,在这个过程中,一个问题的模型被细化/改进,直到它被接受为止。
②流程图

③原型开发分类

根据原型与最终产品之间的关系,原型开发分类分为以下三种:

抛弃式 (throw away):验证和澄清系统的需求描述,重新构造系统。

演化式 (evolutionary):逐步改进和细化原型,将原型进化为最终系统。

增量式 (incremental):在建立软件总体设计基础上,采用增量开发方法,使原型成为最终系统。

此处篇幅较长,点击进入原型实现模型的详解

④适用情况

当客户有一个合理的需求,但是对细节没有概念的时候最适合使用原型实现模型

⑤特点

快速性、迭代性

⑥优缺点

优点:

  • 用户能够感受到实际系统
  • 开发者能很快建造出一些东西

缺点:

  • 原型是粗糙的,没考虑软件总体质量和长期的可维护性
  • 开发者常常要对实现内容折中以使得原型能尽快工作

⑦不适合的领域

  • 嵌入式系统
  • 实时控制系统
  • 科学数值系统

(4)RAD模型

①定义

RAD(Rapid Application Development,快速应用开发)通过使用基于构件的建造方法赢得了快速开发。

②分类

  • 业务建模
  • 数据建模
  • 过程建模
  • 应用生成(编程阶段 - 基于构件)
  • 测试及反复

③流程图

④特点

  • 强调极短的开发时间,每一个主要功能在不到三个月的时间内完成;
  • 强调复用

⑤存在的问题

  • 对于大型的的项目,RAD需要足够的人力资源以建立足够的RAD组;
  • RAD要求开发者和客户承担在一个很短的时间框架下完成一个系统所必要的快速活动;
  • 并非所有应用都适合RAD;
  • 不适合技术风险很高的情况

(5)增量模型

①定义:增量模型融合了瀑布模型的基本成分原型的迭代特性

②举个例子

例如,使用增量模型开发一款字处理软件,那么,这款软件需要做什么呢?

  • 基本的文件管理、编辑和文档生成功能;
  • 更完善的编辑和文档生成能力;
  • 实现拼写和语法检查功能;
  • 完成高级的页面布局功能。

③流程图

④特点

  • 增量1往往是“核心产品”;
  • 本质是迭代的,但强调每一增量均发布一个可操作产品。

⑤优点

  • 面对不能改变的困难时限时,是可考虑的选择;
  • 早期可投入较少人员;
  • 可有计划地管理技术风险。

⑥思考问题

Q:假设一个学校在四个月后要参加教学评估,要求现在开发一个学校综合管理信息系统,如果你是开发者,你会选择哪一种过程模型来开发这个系统,RAD还是增量式的过程模型?为什么?

A:答案是选择RAD过程模型。为什么呢?
原因在于,RAD模型适用于模块化比较强的项目,且必须在60-90天内完成,不迭代,没有一个动作在重复进行。
增量模型则是可迭代的,且增量1是核心产品,每一增量均可操作。比较适用于市场竞争激烈的项目,有利于抢占市场。

(6)螺旋模型

①软件开发可能遇到的风险(引例):

  • 产品交付给用户之后用户可能不满意;
  • 到了预定的交付日期软件可能还未开发出来;
  • 实际的开发成本可能超过预算;
  • 产品完成前一些关键的开发人员可能“跳槽“了;
  • 产品投入市场之前竞争对手发布了一个功能相近、价格更低的软件等;
  • ……

②螺旋模型的基本思想:使用原型及其他方法来尽量降低风险。

③流程图

理解这种模型的一个简便方法,就是把它看作在每个阶段之前都增加了风险分析过程的快速原型模型,如下图所示

④螺旋模型任务区域(4个象限),各象限含义如下:

  • 客户交流——建立开发者和客户之间有效的通信所需的任务;
  • 制定计划——确定软件目标,选定实施方案,弄清项目开发的限制条件;
  • 风险分析——分析评估所选方案,考虑如何识别和消除风险;
  • 实施工程——实施软件开发和验证;
  • 构造及发布——构造、测试、安装和提供用户支持(如文档及培训)所需的任务;
  • 客户评估——评价开发工作,提出修正建议,制定下一步计划。

:四个象限包含制定计划,风险分析,实施工程,客户评估;

​ 此处列出6点是为了更加细分螺旋模型的流程。

⑤优缺点

优点:

  • 随着过程进展演化,开发者和客户能够更好地理解和对待每一个级别上的风险,使用原型实现作为降低风险的机制;
  • 更真实地反映了现实世界;
  • 如应用得当,能在风险变成问题之前降低它。

缺点:

  • 模型的成功依赖于风险评估的专门技术;
  • 是一个较新的模型,功效的确定尚需若干年时间。

⑥适用情况

主要适用于内部开发的大规模软件项目

(7)形式化方法模型

形式化方法使得软件工程师能够通过应用一个严格的、数学的符号体系来规约、开发和验证基于计算机的系统。净室软件工程师是这种方法的一个变种。

通过应用数学分析,二义性、不完整性和不一致性能更容易发现和纠正。

形式化方法目前还很费时且很昂贵

很少有软件开发者具有实用形式化方法所必要的指示,尚需许多方面的培训。

难以与客户进行沟通。

4、敏捷视角下的过程模型

(1)什么是敏捷

  • 普遍存在的变化是敏捷的基本动力

  • 敏捷就是灵活,支持变化的观点

  • 敏捷过程强调过程的可操作性和适应性

(2)敏捷团队必须具备的特点

  • 基本能力
  • 共同目标
  • 精诚合作
  • 决策能力
  • 模糊问题的解决能力
  • 相互信任和尊重
  • 自我组织

(3)几种重要的敏捷过程模型

①极限编程(XP)
  • 包含了策划设计编码测试四个框架活动的规则和实践,具体流程如下:

②自适应软件开发(ASD)
  • ASD的生命周期包含思考协作学习三个阶段

③动态系统开发方法(DSDM)

定义三个不同的迭代循环,前面还加了两个生命周期活动,如下:

  • 可行性研究
  • 业务研究
  • 功能模型迭代
  • 设计和构建迭代
  • 实现迭代
④Scrum(橄榄球模型)

强调使用一系列的软件过程模式,每个过程模式定义一系列开发活动:

  • 待定项——能为用户提供业务价值的项目需求或特征的优先级列表;
  • 冲刺——由工作单元组成,是完成待定项中定义的需求所必需的,能在预定时间段内完成的;
  • Scrum例会——15分钟;
  • 演示——交付软件,客户进行评估。
⑤Crystal
  • 提倡“机动性”的软件开发方法;

  • 包含具有共性的核心元素,每一个都含有独特的角色过程模式工作产品实践等。

⑥特征驱动开发(FDD)
  • 特征,即可以在2周甚至更短时间内实现具有客户价值的功能。

  • 定义五种协作框架

⑦敏捷建模(AM)
  • 有目的的建模
  • 使用多个模型
  • 前进灯
  • 内容重于表达形式
  • 理解模型及工具
  • 适应本地需要

写在最后

看完这篇文章,不妨试问下自己以下问题:

  • 你认为介绍的软件过程模型哪一种最有效,为什么?

  • 举出一个采用增量模型开发的软件项目,并指出各个增量的功能。

  • 当沿着螺旋模型的过程路径向外移动时,你认为正在开发或维护的软件发生了什么变化呢?

  • 分别用图示说明瀑布模型、V模型、原型、RAD、增量模型及螺旋模型这六种模型的原理。

欢迎评论区留下答案٩(๑❛ᴗ❛๑)۶

PS 本文篇幅较长,有错别字欢迎评论区纠正,随时改进~
如果这篇文章对你有帮助,记得留下star哦~

『软件工程2』详解软件工程和软件过程模型相关推荐

  1. 『矩阵论笔记』详解最小二乘法(矩阵形式求导)+Python实战

    详解最小二乘法(矩阵形式求导)+Python实战! 文章目录 一. 矩阵的迹 1.1. 转置矩阵 1.2. 迹的定义 1.3. 七大定理 二. 最小二乘法 2.1. 求解介绍 2.2. 另一角度 2. ...

  2. 『软件工程6』详解软件项目管理之软件范围与估算

    软件项目管理--软件范围与估算 一.软件项目计划 1.目标 2.步骤 二.软件范围 1.软件范围定义 2.软件范围--引例 三.影响估算的因素 四.软件项目资源 1.软件项目资源构成 2.分析图 3. ...

  3. 『软件工程1』详解软件是什么

    软件基本概念 一.什么是产品 二.软件的双重角色 三.软件的涵义及特征 四.软件应用 五.软件危机 六.软件神话 一.什么是产品 1.从用户的角度 产品实际上就是信息,以某种方式使得用户世界更加美好 ...

  4. iOS 开发:『Runtime』详解(二)Method Swizzling

    本文用来介绍 iOS 开发中『Runtime』中的黑魔法Method Swizzling. 通过本文,您将了解到: Method Swizzling(动态方法交换)简介 Method Swizzlin ...

  5. geek软件是干什么的_详解强力卸载软件Geek Uninstaller使用教程

    我们在很多的时候在电脑中安装的防护的软件是会对系统做一些修改的,在不想要使用哪一个软件以后卸载在电脑中还是有残留的情况的,按这个时候小伙伴们可以直接使用专业的清理卸载软件Geek Uninstalle ...

  6. 一文详解Redis企业版软件!

    一.Redis企业版软件概述 Redis企业版软件(Redis Enterprise)是企业级的数据库软件,也是一款实时数据平台,为全球超过8500家知名企业提供实时数据服务.具有线性可扩展性.高可用 ...

  7. Windows系统-安装RabbitMQ过程详解(附带软件安装包)

    RabbitMQ安装配置过程详解(Windows版) 1.介绍: 本次RabbitMQ安装环境相关信息: Win11 64位专业版 erlang opt_win64_24.0 rabbitmq-ser ...

  8. 真题详解(数字签名算法)-软件设计(七十八)

    真题详解(有限自动机)-软件设计(七十七)https://blog.csdn.net/ke1ying/article/details/130748759 可用于数字签名算法的是_____. 答案:非对 ...

  9. dpkg安装软件流程_详解linux安装软件的几种方法

    一.rpm包安装方式步骤: 1.找到相应的软件包,比如soft.version.rpm,下载到本机某个目录: 2.打开一个终端,su -成root用户: 3.cd soft.version.rpm所在 ...

最新文章

  1. 1使用帝国cms开发微信小程序之开发前的约定
  2. usaco The Castle(flood fill)
  3. 当前主流、最新技术回眸(四)
  4. 深入理解Javascript闭包(一)
  5. Two conferences重点词汇
  6. 开发物体识别桌、_【课程总结】AR系统开发“秘籍”大揭秘!
  7. Python_大众点评网站数据爬虫
  8. Hadoop之MapReduce分布式计算
  9. 狗头金一般什么地方有?
  10. 简单的eda实验vga在linux系统中,《EDA实验报告VGA彩条显示.doc
  11. ORCU浅析之安装和作用
  12. python_dataframe总结1
  13. 高中信息技术:信息技术初步、计算机基础、office办公软件
  14. php swool 聊天室,swoole简单的聊天室demo(修正版)
  15. 2011年上半年国内优秀初创企业产品汇总
  16. 声网合伙人王骅:聊聊企业拥抱全球化 关键是什么?
  17. 【06期】单例模式有几种写法?
  18. 奥西450的服务器系统,奥西TDS450
  19. Python语音合成探究(三、合成语音的输出及文字同步显示)
  20. 情侣睡觉为什么在床头总会放一包纸巾?今天终于知道了

热门文章

  1. 毛巾绣/链目绣打版注意事项
  2. Spark - AUC、Accuracy、Precision、Recall、F1-Score 理论与实战
  3. 甘露糖-聚乙二醇-炔基|mannose-PEG-Alkyne|炔基-PEG-甘露糖
  4. Libra区块链钱包开发实录附源码 - LearnDapp系列
  5. 微信小程序与应用服务的关系和“代码安全“
  6. 三国志2霸王的大陆单挑说服几率
  7. docker kill 强制停止容器
  8. 一些有趣的B+树优化实验
  9. Git和GitHub Git和Goes版本控制
  10. 阿里云RDS服务器远程连接失败问题