当前位置: 首页 > news >正文

高架学习笔记之需求工程

目录

一、什么是软件需求

二、需求工程

2.1. 需求获取

2.2. 需求分析

2.3. 形成需求规格

2.4. 需求确认

2.5. 需求管理

2.5.1. 变更控制

2.5.2. 版本控制

2.5.3. 需求跟踪

2.5.4. 需求状态跟踪


一、什么是软件需求

    软件需求目前没有统一的定义,一般是指用户为了解决问题或达到目标所需要的条件或权能,系统或系统部件要满足合同、标准、规范或其他正式规定文档所需具有的条件或权能,以及反映上述两种条件或权能的文档说明。

    软件需求包括业务需求、用户需求以及系统需求,其中业务需求是企业或组织对系统或产品的高层次的期望,反映了企业或组织期望通过系统或产品达到一个什么样的目标;用户需求是系统的实际用户对产品的期望,如财务人员需要系统能够完成哪些任务,管理人员又需要系统完成哪些任务;系统需求则是对需求的计算机化,系统需求包括功能需求,性能需求以及设计约束,其中功能需求直接定义了开发人员必须完成哪些功能,性能需求对系统的响应时间、吞吐率等指标做出要求,设计约束则是指对软件系统设计和实现过程中的限制、规范或条件,比如指定软件系统运行所需的硬件设备或环境要求,规定软件系统需要与特定软件或技术集成或兼容的要求等。

    从项目管理的维度,可以把软件需求分为基本需求、期望需求和兴奋需求;基本需求是指用户明确提出需要有的功能性或非功能性需求,期望需求是指用户没有明确提出,但认为是不需要额外说明也一定要有的功能或非功能性需求,是隐含的需求,兴奋需求则是用户不认为需要有的功能或非功能性需求,实现了兴奋需求不仅需要付出额外的成本,用户也未必会觉得有用,而且兴奋需求的实现一般不会带来额外的回报,所以兴奋需求的实现是有成本且有风险的。

二、需求工程

    需求工程旨在确保软件系统开发过程中对用户需求的准确理解、明确定义和有效管理。需求工程的活动主要划分 需求获取、需求分析、形成需求规格、需求确认、需求管理5个阶段,其中前4个阶段可以统称为需求的开发阶段,而需求的管理阶段又可划分为变更控制、版本控制、需求跟踪、需求状态跟踪四个阶段:

2.1. 需求获取

    需求获取是指识别和收集与软件系统相关的各种需求。这包括与利益相关者沟通、分析现有系统和文档、进行用户调研等活动,以获取全面的需求信息。

    需求获取的方法包括:用户面谈、需求专题讨论会、问卷调查、现场观察、原型化方法、头脑风暴法等。

2.2. 需求分析

    需求分析是在需求识别的基础上,对收集到的需求进行分析和整理,以理解需求之间的关系、优先级和约束条件。需求分析包括结构化分析以及面向对象分析

2.3. 形成需求规格

    形成需求规格也称为需求文档化或需求定义, 目的在于按照相关标准,形成需求规格说明书(SRS),作为后续软件系统开发的指南。主要有两种方法:严格定义法和原型法。严格定义法要求所有需求都能预先定义,有结构化的思想在里面;原型法通过开发实际的、可供用户参与的模型来加强项目参与者之间的交流,其需求往往无法在开发前就被准确地说明,通过增量迭代的方法来完成需求的定义。

2.4. 需求确认

    需求确认是指在需求规范完成后,需求工程师会与利益相关者一起验证需求,确保需求的正确性、完整性、一致性、可测试性和可行性。包含有效性检查、一致性检查、可行性检查和确认可验证性。需求经过确认之后会形成需求的基线,后续的管理工作将围绕着需求的基线进行管理。

    需求确认的方法主要有需求评审和需求测试两种,需求评审包括正式评审和非正式评审,需要甲乙双方共同参与,确认需求内容;需求测试是通过提出一些场景来验证按照需求开发出来的系统是否符合标准。最终由用户签字确认需求,并成为最终软件的验收标准之一。

2.5. 需求管理

2.5.1. 变更控制

    需求的变更就是对需求基线的变更,变更控制过程用来评估提议的变更并对其进行跟踪,变更控制过程包括变更申请、变更评估、变更决策、变更实施、变更验证、沟通存档。其中对变更进行决策时需要变更控制委员会(Change Control Board, CCB)的参与。

    变更控制委员会(CCB)负责裁定接受哪些变更。CCB由多方成员共同组成,只决定是否接受变更,而不提出变更方案。

2.5.2. 版本控制

    需求基线的每次变更都会产生一个版本,版本控制即为对不同版本的管理和控制。

2.5.3. 需求跟踪

    需求跟踪是对需求基线的落实及实现的跟踪,它提供了由需求到产品实现整个过程范围的明确查阅能力,它的目的是维护“需求-设计-编程-测试”之间的一致性,确保所有的工作成果符合用户需求。需求跟踪有两种方式:正向跟踪及逆向跟踪。正向跟踪是指跟踪所有的需求是否都得到了实现;逆向跟踪则是指系统所有的功能是否都能在需求中找到出处。

2.5.4. 需求状态跟踪

    需求状态跟踪是指在软件开发项目中追踪每个需求的当前状态和进展情况。需求状态通常包括需求的提出、分析、设计、实现、测试、验证等不同阶段。需求状态跟踪的主要目的是帮助团队了解每个需求的当前状态,及时发现和解决可能存在的问题或延迟,以确保项目按时交付并满足质量标准。

相关文章:

高架学习笔记之需求工程

目录 一、什么是软件需求 二、需求工程 2.1. 需求获取 2.2. 需求分析 2.3. 形成需求规格 2.4. 需求确认 2.5. 需求管理 2.5.1. 变更控制 2.5.2. 版本控制 2.5.3. 需求跟踪 2.5.4. 需求状态跟踪 一、什么是软件需求 软件需求目前没有统一的定义,一般是指用…...

mysql基础2多表查询

多表查询 多表关系: 一对多 案例: 部门 与 员工的关系 关系: 一个部门对应多个员工,一个员工对应一个部门 实现: 在多的一方建立外键,指向一的一方的主键 多对多 案例: 学生 与 课程的关系 关系: 一个学生可以选修多门课程,一门课程也可以…...

Qt 写一个邮件发送程序

最近在完成一个邮箱代替的告警功能&#xff0c;写了一个邮件发送的demo 以下为代码&#xff1a; #ifndef MAINWINDOW_H #define MAINWINDOW_H#include <QMainWindow> #include<QTcpSocket> namespace Ui { class MainWindow; }class MainWindow : public QMainWin…...

swagger3快速使用

目录 &#x1f37f;1.导入依赖 &#x1f32d;2.添加配置文件 &#x1f9c2;3.添加注解 &#x1f96f;4.访问客户端 1.导入依赖 引入swagger3的依赖包 <dependency><groupId>io.springfox</groupId><artifactId>springfox-boot-starter</artif…...

一键入门Ubuntu22!

目录 一、安装 二、常用目录 三、常用指令 四、用户指令 五、ssh与scp 六、服务相关 七、Python与Pycharm 八、Vim编辑器 九、Ubuntu22下使用Mysql 十、Ubuntu22下使用mongodb 十一、Ubuntu22下使用redis Ubuntu是一个基于Debian的开源操作系统&#xff0c;由Canoni…...

阿里云服务器价格购买价格表,2024新版报价查询

2024年腾讯云服务器优惠价格表&#xff0c;一张表整理阿里云服务器最新报价&#xff0c;阿里云服务器网整理云服务器ECS和轻量应用服务器详细CPU内存、公网带宽和系统盘详细配置报价单&#xff0c;大家也可以直接移步到阿里云CLUB中心查看 aliyun.club 当前最新的云服务器优惠券…...

实现防抖函数并支持第一次立刻执行(vue3 + ts环境演示)

1、先看一效果&#xff1a; 2、实现思路&#xff1a; 使用定时器setTimeout和闭包实现常规防抖功能&#xff1b;增加immediate字段控制第一次是否执行一次函数&#xff08;true or false&#xff09;&#xff1b;增加一个flag标识&#xff0c;在第一次执行时&#xff0c;将标…...

WPF —— DataGrid数据网格

1 &#xff1a;DataGrid简介 DataGrid 是数据网格 : 可以显示网格数据的控件&#xff0c;通过自定义列模版 来去实现各种网格效果 &#xff0c; 可以使用以下几中标签显示不同数据 2 &#xff1a;DataGrid常用的组件 显示文本: DataGridTextColumn 显示复选框: DataGridChec…...

牛客题霸-SQL进阶篇(刷题记录一)

本文基于前段时间学习总结的 MySQL 相关的查询语法&#xff0c;在牛客网找了相应的 MySQL 题目进行练习&#xff0c;以便加强对于 MySQL 查询语法的理解和应用。 由于涉及到的数据库表较多&#xff0c;因此本文不再展示&#xff0c;只提供 MySQL 代码与示例输出。 部分题目因…...

网络安全实训Day12

写在前面 注意根据笔记中的缩进判断该文本所在层级。 网络空间安全实训-网络安全技术 SSL VPN SSL协议 定义&#xff1a;一种应用层的安全保护技术 工作流程 1.客户端与服务器通过三次握手建立TCP连接 2.客户端向服务器发送Client-Hello信息&#xff0c;消息中包含希望访问的…...

对话Midjourney创始人:图片仅是起步,人工智能将全面改变学习、创意和组织。

ChatGPT狂飙160天&#xff0c;世界已经不是之前的样子。 新建了人工智能中文站https://ai.weoknow.com 每天给大家更新可用的国内可用chatGPT资源 ​ 发布在https://it.weoknow.com 关注我 Midjourney 是一家神奇的公司&#xff0c;11 人改变世界&#xff0c;创造伟大的产品。…...

Elasticsearch:将 ILM 管理的数据流迁移到数据流生命周期

警告&#xff1a;此功能处于技术预览阶段&#xff0c;可能会在未来版本中更改或删除。 Elastic 将努力解决任何问题&#xff0c;但技术预览版中的功能不受官方 GA 功能的支持 SLA 的约束。目前的最新版本为 8.12。 在本教程中&#xff0c;我们将了解如何将现有数据流&#xff0…...

LeetCode刷题记录——day6

1、https://leetcode.cn/problems/length-of-last-word/description/?envTypestudy-plan-v2&envIdtop-interview-150 直接从后往前遍历就好 class Solution { public:int lengthOfLastWord(string s) {int length0;int lens.length();for(int ilen-1;i>0;i--){if(s[i]…...

C++String类

1. 前言 String是C中操作字符串的类&#xff0c;它是在比较早的时候设计的STL模板&#xff0c;因此在某些地方设计的有些冗余 对于String类&#xff0c;不仅仅是学会使用它&#xff0c;更重要的是要从底层去理解它&#xff1b;本篇文章将从底层出发&#xff0c;模拟实现常用的S…...

Linux docker7--私有镜像仓库registry和UI搭建及使用

一、对于开源的镜像&#xff0c;如redis&#xff0c;nginx等&#xff0c;可以通过官方仓库Docker Hub&#xff0c;或者国内的阿里云等共有仓库下载获取到镜像。但是企业内对于自己的研发产品不可能往公共仓库去发布镜像的&#xff0c;一般都会搭建私有的镜像仓库&#xff0c;保…...

IDS入侵检测系统分为两大类。

一、基于签名的IDS和基于异常的IDS。 基于签名的Ids主要依赖于已知的攻击模式库来检测入侵行为&#xff0c;适用于检测已知的攻击模式。 基于异常的Ids则关注网络流量的行为特征&#xff0c;通过分析数据包之间的关系和统计模型来判断是否存在异常行为&#xff0c;更适用于检…...

为什么元素显示的样式跟我设置的不一样?CSS优先级详解

一、什么是CSS中的选择器优先级&#xff1f; 在CSS中&#xff0c;选择器优先级是指确定应用于元素的最相关CSS声明的算法。这个优先级决定了哪个样式规则将被应用到元素上。根据选择器的类型和特定性&#xff0c;CSS规定了不同的优先级&#xff0c;例如ID选择器比类选择器具有更…...

C语言动态内存的管理

前言 本篇博客就来探讨一下动态内存&#xff0c;说到内存&#xff0c;我们以前开辟空间大小都是固定的&#xff0c;不能调整这个空间大小&#xff0c;于是就有动态内存&#xff0c;可以让我们自己选择开辟多少空间&#xff0c;更加方便&#xff0c;让我们一起来看看动态内存的有…...

CASIA数据集转png HWDB2.0-2.2

https://nlpr.ia.ac.cn/databases/handwriting/Home.html CASIA在线和离线中文手写数据库 https://nlpr.ia.ac.cn/databases/handwriting/Offline_database.html CASIA-HWDB2.0-2.2 离线文本数据库是由孤立字符数据集的作者制作的。每人撰写了五页给定文本。由于数据丢失&a…...

学习或复习电路的game推荐:nandgame(NAND与非门游戏)、Turing_Complete(图灵完备)

https://www.nandgame.com/ 免费 https://store.steampowered.com/app/1444480/Turing_Complete/ 收费&#xff0c;70元。据说可以导出 Verilog &#xff01;...

RestClient

什么是RestClient RestClient 是 Elasticsearch 官方提供的 Java 低级 REST 客户端&#xff0c;它允许HTTP与Elasticsearch 集群通信&#xff0c;而无需处理 JSON 序列化/反序列化等底层细节。它是 Elasticsearch Java API 客户端的基础。 RestClient 主要特点 轻量级&#xff…...

可靠性+灵活性:电力载波技术在楼宇自控中的核心价值

可靠性灵活性&#xff1a;电力载波技术在楼宇自控中的核心价值 在智能楼宇的自动化控制中&#xff0c;电力载波技术&#xff08;PLC&#xff09;凭借其独特的优势&#xff0c;正成为构建高效、稳定、灵活系统的核心解决方案。它利用现有电力线路传输数据&#xff0c;无需额外布…...

【Redis技术进阶之路】「原理分析系列开篇」分析客户端和服务端网络诵信交互实现(服务端执行命令请求的过程 - 初始化服务器)

服务端执行命令请求的过程 【专栏简介】【技术大纲】【专栏目标】【目标人群】1. Redis爱好者与社区成员2. 后端开发和系统架构师3. 计算机专业的本科生及研究生 初始化服务器1. 初始化服务器状态结构初始化RedisServer变量 2. 加载相关系统配置和用户配置参数定制化配置参数案…...

测试markdown--肇兴

day1&#xff1a; 1、去程&#xff1a;7:04 --11:32高铁 高铁右转上售票大厅2楼&#xff0c;穿过候车厅下一楼&#xff0c;上大巴车 &#xffe5;10/人 **2、到达&#xff1a;**12点多到达寨子&#xff0c;买门票&#xff0c;美团/抖音&#xff1a;&#xffe5;78人 3、中饭&a…...

2025盘古石杯决赛【手机取证】

前言 第三届盘古石杯国际电子数据取证大赛决赛 最后一题没有解出来&#xff0c;实在找不到&#xff0c;希望有大佬教一下我。 还有就会议时间&#xff0c;我感觉不是图片时间&#xff0c;因为在电脑看到是其他时间用老会议系统开的会。 手机取证 1、分析鸿蒙手机检材&#x…...

【C语言练习】080. 使用C语言实现简单的数据库操作

080. 使用C语言实现简单的数据库操作 080. 使用C语言实现简单的数据库操作使用原生APIODBC接口第三方库ORM框架文件模拟1. 安装SQLite2. 示例代码:使用SQLite创建数据库、表和插入数据3. 编译和运行4. 示例运行输出:5. 注意事项6. 总结080. 使用C语言实现简单的数据库操作 在…...

管理学院权限管理系统开发总结

文章目录 &#x1f393; 管理学院权限管理系统开发总结 - 现代化Web应用实践之路&#x1f4dd; 项目概述&#x1f3d7;️ 技术架构设计后端技术栈前端技术栈 &#x1f4a1; 核心功能特性1. 用户管理模块2. 权限管理系统3. 统计报表功能4. 用户体验优化 &#x1f5c4;️ 数据库设…...

A2A JS SDK 完整教程:快速入门指南

目录 什么是 A2A JS SDK?A2A JS 安装与设置A2A JS 核心概念创建你的第一个 A2A JS 代理A2A JS 服务端开发A2A JS 客户端使用A2A JS 高级特性A2A JS 最佳实践A2A JS 故障排除 什么是 A2A JS SDK? A2A JS SDK 是一个专为 JavaScript/TypeScript 开发者设计的强大库&#xff…...

Java编程之桥接模式

定义 桥接模式&#xff08;Bridge Pattern&#xff09;属于结构型设计模式&#xff0c;它的核心意图是将抽象部分与实现部分分离&#xff0c;使它们可以独立地变化。这种模式通过组合关系来替代继承关系&#xff0c;从而降低了抽象和实现这两个可变维度之间的耦合度。 用例子…...

关于uniapp展示PDF的解决方案

在 UniApp 的 H5 环境中使用 pdf-vue3 组件可以实现完整的 PDF 预览功能。以下是详细实现步骤和注意事项&#xff1a; 一、安装依赖 安装 pdf-vue3 和 PDF.js 核心库&#xff1a; npm install pdf-vue3 pdfjs-dist二、基本使用示例 <template><view class"con…...