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

news2025/1/12 15:58:16

需求分析

需求分析的任务

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

                                                                                                                     —— 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.coloradmin.cn/o/1675538.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

CAN模块开发问题概述

问题一 问题描述 工作环境:ECU外接canoe 操作:使用CANoe模拟发送NM报文,然后停发或者断开CANoe 现象:程序跑死,调用call stack查看压栈情况如下图所示 定位代码如下图所示。可见是由于CAN模块在设置Controller状态时…

tomcat--目录结构和文件组成

目录结构 目录说明bin服务启动,停止等相关程序和文件conf配置文件lib库目录logs日志记录webapps应用程序,应用部署目录workjsp编译后的结果文件,建议提前预热访问 /usr/local/apache-tomcat-8.5.100/work/Catalina/localhost/ROOT/org/apac…

[笔试训练](二十二)064:添加字符065:数组变换066:装箱问题

目录 064:添加字符 065:数组变换 066:装箱问题 064:添加字符 添加字符_牛客笔试题_牛客网 (nowcoder.com) 题目: 题解: 枚举所有A,B字符串可能的对应位置,得出对应位置不同字符数量的最小情况 两字符串的字符数量差n-m&…

Hadoop 3.4.0+HBase2.5.8+ZooKeeper3.8.4+Hive+Sqoop 分布式高可用集群部署安装 大数据系列二

创建服务器,参考 虚拟机创建服务器 节点名字节点IP系统版本master11192.168.50.11centos 8.5slave12192.168.50.12centos 8.5slave13192.168.50.13centos 8.5 1 下载组件 Hadoop:官网地址 Hbase:官网地址 ZooKeeper:官网下载 Hive:官网下载 Sqoop:官网下载 为方便同学…

【已解决】力扣打不开

表现: 1.访问国内其他网站都没有问题 2.访问github也能成功 3.wifi没有问题 4.连接同网络的其他主机能打开 唯独力扣打不开,可能是DNS解析错误 》自己网络配置问题 解决办法【亲测可行】 找可用的hosts 打开站长之家,进行DNS查询&#xff…

FreeRTOS事件标志组

目录 一、事件标志组的概念 1、事件标志位 2、事件标志组 二、事件标志组相关API 1、创建事件标志组 2、设置事件标志位 3、清除事件标志位 4、等待事件标志位 三、事件标志组实操 1、实验需求 2、CubeMX配置 3、代码实现 一、事件标志组的概念 1、事件标志位 表…

128.Mit6.S081-实验1-Xv6 and Unix utilities(下)

今天我们继续实验一接下来的内容。 一、pingpong(难度easy) 1.需求 编写一个程序&#xff0c;使用 UNIX 系统调用通过一对管道(每个方向一个管道)在两个进程之间 "ping-pong" 传递一个字节。父进程应该向子进程发送一个字节; 子进程应该打印<pid>: received p…

短视频语音合成:成都鼎茂宏升文化传媒公司

短视频语音合成&#xff1a;技术革新与创意融合的新篇章 随着科技的飞速发展&#xff0c;短视频已经成为人们生活中不可或缺的一部分。在这个快速变化的时代&#xff0c;短视频语音合成技术正逐渐崭露头角&#xff0c;以其独特的魅力和广泛的应用前景&#xff0c;吸引了众多创…

R语言:ROC分析

> install.packages("pROC") > library(pROC) > inputFile"结果.txt" > rtread.table(inputFile, headerT, sep"\t", check.namesF, row.names1) > head(rt) con treat TCGA-E2-A1L7-11A-con…

6. 第K小的和-二分

6.第K小的和 - 蓝桥云课 (lanqiao.cn) #include <bits/stdc.h> #define int long long #define endl \n using namespace std; int n,m,k,an[100005],bm[100005]; int check(int x){int res0;//序列C中<x的数的个数for(int i0;i<n;i){//遍历数组A&#xff0c;对于每…

怎么得到所有大写字母/小写字母组成的字符串

有时候&#xff0c;可能需要获取a~z、A~Z组成的26个字母的字符串&#xff0c;这篇文章介绍一种简单的方法。 只需要几句简单到不能再简单的代码&#xff01;你不会还在傻傻地一个个字母敲吧~ /*** author heyunlin* version 1.0*/ public class Example {/*** 小写字母*/priv…

Vscode编辑器 js 输入log自动补全

最近换了新电脑&#xff0c;新下载了Vscode&#xff0c;记录一下设置项。 Vscode 版本 想要的效果 js文件中输入log&#xff08;点击tab键&#xff09;&#xff0c;自动补全为 console.log() Vscode 文件》首选项》设置 搜索&#xff1a;snippets Emmet: Show Suggestions…

HTML常用标签-表单标签

表单标签 1 表单标签2 表单项标签2.1 单行文本框2.2 密码框2.3 单选框2.4 复选框2.5 下拉框2.6 按钮2.7 隐藏域2.8 多行文本框2.9 文件标签 1 表单标签 表单标签,可以实现让用户在界面上输入各种信息并提交的一种标签. 是向服务端发送数据主要的方式之一 form标签,表单标签,其内…

3ds Max与Maya不同之处?两者哪个更适合云渲染?

3ds Max 和 Maya 都是知名的3D软件&#xff0c;各有其特色。3ds Max 以直观的建模和丰富的插件生态闻名&#xff1b;Maya 则在动画和角色创作方面更为出色。两者都支持云渲染技术&#xff0c;能帮助用户在云端高效完成项目。 一、3ds Max和Maya之间的主要区别&#xff1a; 3ds…

web入门练手案例(二)

下面是一下web入门案例和实现的代码&#xff0c;带有部分注释&#xff0c;倘若代码中有任何问题或疑问&#xff0c;欢迎留言交流~ 数字变色Logo 案例描述 “Logo”是“商标”的英文说法&#xff0c;是企业最基本的视觉识别形象&#xff0c;通过商标的推广可以让消费者了解企…

两小时看完花书(深度学习入门篇)

1.深度学习花书前言 机器学习早期的时候十分依赖于已有的知识库和人为的逻辑规则&#xff0c;需要人们花大量的时间去制定合理的逻辑判定&#xff0c;可以说是有多少人工&#xff0c;就有多少智能。后来逐渐发展出一些简单的机器学习方法例如logistic regression、naive bayes等…

产品品牌CRUD

文章目录 1.renren-generator生成CRUD1.数据库表设计1.数据表设计2.分析 2.代码生成器生成crud1.查看generator.properties&#xff08;不需要修改&#xff09;2.修改application.yml 连接的数据库修改为云数据库3.启动renren-generator模块4.浏览器访问 http://localhost:81/5…

ip addr 或 ip address 是 Linux 系统中的一个命令,用于显示或修改网络接口的地址信息。

ip addr 或 ip address 是 Linux 系统中的一个命令&#xff0c;用于显示或修改网络接口的地址信息。这个命令是 iproute2 软件包的一部分&#xff0c;通常在现代 Linux 发行版中都是预装的。 当你运行 ip addr 或 ip address 命令时&#xff0c;你会看到系统上所有网络接口的地…

ssh错误 ssh_exchange_identification: Connection closed by remote host

一 背景 今天使用终端ssh链接服务器报错&#xff0c;昨天还好的&#xff0c;今天就报错&#xff0c;原以为是服务器ip变了&#xff0c;但是同事使用原来ip可以链接&#xff0c;本人怀疑ssh链接人员是不是超出限制&#xff0c;于是沿着这思路解决&#xff0c;果然成功了。 二 …

.NET周刊【5月第2期 2024-05-12】

国内文章 C#在工业数字孪生中的开发路线实践 https://mp.weixin.qq.com/s/b_Pjt2oii0Xa_sZp_9wYWg 这篇文章探讨了C#在工业数字孪生技术中的应用&#xff0c;介绍了三种基于C#的数字孪生系统实现方案&#xff1a; WPF Unity&#xff1a;结合WPF技术和Unity引擎&#xff0c…