软件工程期末复习(6)需求分析的任务

需求分析

需求分析的任务

“建造一个软件系统的最困难的部分是决定要建造什么……没有别的工作在做错时会如此影响最终系统,没有别的工作比以后矫正更困难。”                                                      

                                                                                                                     —— Fred Brooks

 

需求难以建立的原因:

  • 误解
  • 交流障碍
  • “完整性”问题
  • 需求永远不会稳定
  • 用户意见不统一
  • 错误的要求
  • 认识混淆

 

需求为何重要?------软件项目失败的原因:

  •  不完整的需求(13.1%)
  • 缺少用户的参与(12.4%)
  • 缺乏资源(10.6%)
  • 不切实际的期望(9.9%)
  • 缺乏行政支持(9.3%)
  • 改动需求和说明(8.7%)
  • 缺少计划(8.1%)
  • 不再需要该系统(7.5%)

需求为何重要?------有关软件错误的一些认识:

事实1: 在软件生命周期中,一个错误发现得越晚,修复错误的费用越高

事实2:   许多错误是潜伏的,并且在错误产生后很长一段时间才被检查出来 

Boehm从TRW公司所做的软件项目中得出结论:所有被检测出来的错误中的54%实际上是在编码和单元测试阶段以后才被发现的;更糟糕的是,此类错误中的绝大部分(占45%)是属于需求和设计阶段的,而编码阶段的错误只占9%。 

事实3:     在需求过程中会产生很多错误

DeMarco在一份研究报告中指出,被检查出来的错误的56%产生的根源可以追溯到需求阶段。AIRMICS所进行的一项调查发现,在一份美国军方大型管理信息系统的需求规格说明书中存在着500多个错误,当然这仅仅是一个软件项目中的一次调查。

事实4:   在需求阶段,代表性的错误为疏忽、不一致和二义性 

美国海军研究实验室对海军A-7E飞机上的飞行操作程序进行实地测试,得出的研究数据表明: A-7E项目中77%的需求错误特点是不明确-疏忽、不一致和二义性。

  • 49% 不正确的事实
  • 31% 疏忽
  • 13% 不一致
  • 5%  二义性
  • 2%  放错位置

 事实5 :  需求错误是可以被检查出来的

Basili和Weiss的数据表明:在A-7E的软件定义文档中,33%的需求错误是通过人工检查出来的。 Celko觉得利用自动分析工具能够从SRS中检查出来相当数量的错误。

由上面这些事实,能得出如下四点结论:

  • 在需求过程中会产生很多错误(事实3和4)
  • 许多错误并没有在早期被发现(事实2)
  • 这样的错误是能够在产生的初期被检查出来的(事实5)
  • 如果没有及时检查出来这些错误,软件费用会直线上升(事实1)

需求过程不仅是可能的而且也是值得的

什么是需求?

  • 需求:就是系统的特征,或对系统为达到某个目标所能做的事情的一个描述。
  • 需求:是对问题信息和系统行为、特性、设计及制造约束的描述的集合。
  • 需求过程本质:在问题空间与求解空间中间架设桥梁。

项目干系人(Stakeholder)

  • 直接或间接从正在开发的系统中获益的人
    • 业务运行管理人员
    • 产品管理人员
    • 市场销售人员
    • 内部和外部客户
    • 最终用户
    • 顾问
    • 产品工程师、软件工程师、支持和维护工程师以及其他人员

 项目干系人需求、系统需求:

  • 需求可能首先从项目干系人角度表达为一个非形式化的、不详细的、高层的描述,称为项目干系人需求(客户需求);
  • 然后从开发者角度出发,发展成更详细的形式,即系统需求。

功能需求、非功能需求

功能需求:系统与环境间的交互——描述系统必须支持的功能和过程的系统需求。

非功能需求:客户给出的具体约束、指标——描述操作环境和性能目标的系统需求。

二者的区别:功能需求描述系统应该做什么,非功能需求则为如何实现这些需求设定约束。

例如:

功能需求可能声明:系统必须提供一些验证系统用户身份的工具

非功能需求可能声明:验证过程必须在4秒内完成。

应该考虑到的非功能需求 

  • 性能:实时性、资源利用、硬件配置限制、精确度
  • 可靠性:有效性、完整性
  • 安全/保密性
  • 运行限制:使用频度、运行期限、控制方式(如本地或远程)、对操作员的要求
  • 物理限制:系统的规模等限制
  • 用户界面友好性:易用性

需求的特征

  • 正确性:要确保需求的表达中没有引入错误(faults)。
  • 一致性:确保没有互相冲突、矛盾的需求;确保没有不确定的需求。
  • 完整性:如果需求描述了所有可能的状态,以及状态的变化、输入、过程和约束,那么这组需求就是完整的。
  • 现实性:确保客户要求系统做的事真的能做到。
  • 实用性:确保需求和要解决的问题有直接关系。
  • 可检验性:必须能写出测试来说明需求已被满足。
  • 可回溯性:保证每个系统功能都能追溯到一组要求它的需求;确保很容易找到处理系统特定方面的某一组需求。 

需求文档

需求文档的可能使用者:
  • 系统客户:需要阅读需求文档来检验是否表达了他们的需要;
  • 软件项目管理者:需求文档是制定项目计划的基础之一;
  • 系统工程师:需要理解待开发系统;
  • 系统测试工程师:要依据需求文档制作测试用例,验证开发出的系统是否满足要求;
  • 系统维护人员:使用需求文档理解初始系统的特性和系统不同部分之间的关系。
两种需求文档:
  • 需求定义(需求描述)
    • 用应用域术语编写
    • 彻底列举客户/用户想要系统做些什么
    • 由客户/用户和开发人员共同编写
  • 需求规约(软件需求规格说明,Software Requirements Specification)
    • 用开发人员擅长的技术术语编写
    • 需求定义的技术性版本,方便设计人员理解
    • 由分析人员编写

需求分析的任务

  • 必须理解并描述问题的信息域,根据这条准则应该建立数据模型;
  • 必须定义软件应完成的功能,这条准则要求建立功能模型;
  • 必须描述作为外部事件结果的软件行为,这条准则要求建立行为模型;
  • 必须对描述信息、功能和行为的模型进行分解,用层次的方式展示细节
  • 确定对系统的综合要求
    • 功能需求
    • 性能需求
    • 可靠性和可用性需求
    • 出错处理需求
    • 接口需求:用户接口需求;硬件接口需求;软件接口需求;通信接口需求
    • 约束:精度;工具和语言约束;设计约束;应该使用的标准;应该使用的硬件平台 逆向需求
    • 将来可能提出的要求
  • 分析系统的数据要求
    • 建立数据模型
      • E-R图
    • 复杂数据结构的描述
      • 数据字典
      • 层次方框图
      • Warnier图
    • 数据库
      • 数据规范化
  • 导出系统的逻辑模型
    • 软件系统详细的逻辑模型通常用数据流图、实体-联系图、状态转换图、数据字典和主要的处理算法描述
  • 修正系统的开发计划
    • 可以比较准确地估计系统的成本和进度,修正以前制定的开发计划。

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

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

相关文章

C++ 关键字 :using

在 C 庞大语法体系中, using 关键字十分的灵活多用,它可不简单。 除了常规的引入命名空间之外,它还可用于引入枚举类型枚举器、定义常规类型别名、模板类型别名等。在定义常规类型别名方面与C语言中的typedef、#define与之相似,但…

wangEditor富文本编辑器与layui图片上传

记录&#xff1a;js 显示默认的wangEditor富文本编辑器内容和图片 <style>body {background-color: #ffffff;}.layui-form-select dl{z-index:100000;} </style> <div class"layui-form layuimini-form"><div class"layui-form-item"…

求学生平均成绩(C语言)

一、运行结果&#xff1b; 二、源代码&#xff1b; # define _CRT_SECURE_NO_WARNINGS # include <stdio.h>//声明平均数函数average; float average(float score[10]);int main() {//初始化变量值&#xff1b;float score[10], aver;int i 0;//填充数组&#xff1b;pr…

数据库系统概论(超详解!!!)第八节 数据库设计

1.数据库设计概述 数据库设计是指对于一个给定的应用环境&#xff0c;构造&#xff08;设计&#xff09;优化的数据库逻辑模式和物理结构&#xff0c;并据此建立数据库及其应用系统&#xff0c;使之能够有效地存储和管理数据&#xff0c;满足各种用户的应用需求&#xff0c;包…

运维别卷系列 - 云原生监控平台 之 01.prometheus 入门和部署

文章目录 [toc]什么是 PrometheusPrometheus 架构及其一些生态系统组件Prometheus 的工作模式Prometheus 的适用场景Prometheus 的不适用场景Prometheus 词汇表 Prometheus 启动参数Prometheus 配置文件通用占位符定义配置文件示例解释服务发现 Prometheus 部署创建 namespace创…

System V IPC(进程间通信)机制详解

文章目录 一、引言二、System V IPC的基本概念1、IPC结构的引入2、IPC标识符&#xff08;IPC ID&#xff09;3、S ystem V的优缺点 三、共享内存&#xff08;Shared Memory&#xff09;1、共享内存的基本概念2、共享内存的创建&#xff08;shmget&#xff09;3、共享内存的附加…

51. UE5 RPG 自定义FGameplayEffectContext

我们期望能够通过FGameplayEffectContext将此次技能造成的伤害是否触发格挡和暴击的参数传递到AttributeSet中&#xff0c;所以需要实现自定义一个FGameplayEffectContext类&#xff0c;来增加对应的配置。 创建自定义类文件 首先在Public目录上右键&#xff0c;选择添加一个…

考研数学|李林《880》做不动,怎么办!?看这一篇!

在考研数学的备考过程中&#xff0c;遇到难题是很常见的情况&#xff0c;尤其是当你尝试解决李林880习题集中的问题时。他以其难度和深度著称&#xff0c;旨在帮助考生深入理解数学分析的复杂概念。 如果你在解题过程中感到困难&#xff0c;这并不是你个人的问题&#xff0c;而…

Git 的原理与使用(中)

Git 的原理与使用&#xff08;上&#xff09;中介绍了Git初识&#xff0c;Git的安装与初始化以及工作区、暂存区、版本库相关的概念与操作&#xff0c;本文接着上篇的内容&#xff0c;继续深入介绍Git在的分支管理与远程操作方面的应用。 目录 五、分支管理 1.理解分支 2.创…

基于spingboot,vue线上辅导班系统

目录 项目介绍 图片展示 运行环境 获取方式 项目介绍 权限划分&#xff1a;用户&#xff0c;管理员 具有前后台展示&#xff0c;前台供用户使用&#xff1b;用户具有自己的后台&#xff0c;查看自己的老师课程等&#xff1b;管理员具有最大的权限后台。 用户&#xff1a…

Jmeter接口测试和性能测试

&#x1f345; 视频学习&#xff1a;文末有免费的配套视频可观看 &#x1f345; 点击文末小卡片 &#xff0c;免费获取软件测试全套资料&#xff0c;资料在手&#xff0c;涨薪更快 目前最新版本发展到5.0版本&#xff0c;需要Java7以上版本环境&#xff0c;下载解压目录后&…

数据结构之二叉树详解[1]

在前面我们介绍了堆和二叉树的基本概念后&#xff0c;本篇文章将带领大家深入学习链式二叉树。 1.预备知识 2.二叉树结点的创建 3.二叉树的遍历 3.1前序遍历 3.2中序遍历 3.3 后序遍历 4.统计二叉树的结点个数 5.二叉树叶子结点的个数 6.二叉树第k层的结点个数 7.总结 …