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

什么是非功能性需求,它们如何影响产品开发?

我们在选购新车时,会预设一些选购的标准,比如GPS导航必须能够保存目的地,或者必须要买黑色的车。我们可能下意识以为这些是功能性需求,但实际上这些特性都是与用户体验相关的非功能性需求。

一、什么是非功能性需求(NFR)?

非功能性需求是对软件系统的全局性约束,包括但不限于开发成本、运营成本、性能、可靠性、可维护性、可移植性和扩展性等。一个与功能无关,但与可靠性、效率、可用性、可维护性和可移植性等属性相关的需求。

在系统工程和需求工程中,非功能性需求是一个指定可以用来判断系统操作的标准,而不是特定行为的需求。

在描述非功能性需求时常会用到一些副词或修饰语,如“系统应能快速打印发票”,或“系统应在确保信息安全的情况下打印出发票”。

软件的非功能性需求关乎用户体验。忽视这些需求可能会导致项目延期,预算超支,用户满意度降低,也可能会导致项目目标不明确,进而导致产品偏离用户的期望。

非功能性需求弥补了开发者认为客户想要的和客户真正想要的之间的差距。

研究显示,软件开发成本中的60%到80%用于修复产品存在的问题,完善的非功能性需求可以消除约50%到80%的产品缺陷。

既然我们已经知道了非功能性需求的重要性,那么问题来了:如何有效地将非功能性需求融入到产品开发过程中呢?

二、非功能性需求关注产品的”性能”

产品的”性能”包括质量、可靠性、可制造性、可用性、可服务性、可升级性等。

非功能性需求关注用户体验,定义了系统的质量、约束条件或外部接口等方面的要求。如果我们想设计出一个具有可扩展性的系统,仅凭口头描述往往不够清楚,需要将目标具体化,比如:“构建出一个在未来24个月内能够管理至少50,000名用户的系统,以防止系统崩溃对用户造成困扰”。

另外,非功能性需求还可能涵盖以下方面:

  • 法律法规或相关规定。
  • 定义软件的质量属性。
  • 确保关键领域的性能表现,例如可靠性、可用性和可扩展性。
  • 提升用户体验,使系统更易于操作,并最大程度地减少返工。

就像购车一样,不同的人获得最佳用户体验所要求的产品特性不同。你可能需要加热座椅,而其他人则可能想要三排座椅。所以,你为项目定义的非功能性需求会根据客户期望而变化。然而,一个可能的非功能性需求类别列表可以作为你的起始点,帮助你思考在你的需求列表中应该包含哪些非功能性需求。

三、非功能性需求的不同类别?

把非功能性需求想象成一种容器,里面装载的是与用户体验密切相关的重要属性。要记住,非功能性需求并不是关于产品将要完成什么任务(那是功能性需求的范畴),而是关于这个项目将要达到的目标或理想状态。

如果你选择了正确的容器并且衡量了正确的事物,那么你就可以放心,你交付的产品会满足客户的期望——因为你已经明确地定义了这些期望。每个人都在同一认知水平上,这在你集中管理你的需求时,会进一步增强。

接下来,让我们看看一些常见的非功能性需求类别:

  1. 性能和可扩展性:确定所需的响应时间、性能标准和其他与性能相关的属性。系统生成结果的速度有多快?系统在高负荷下的性能如何?
  2. 操作限制:这部分涉及产品开发过程中必须遵守的特定软件需求、系统需求,以及运行时候的约束。
  3. 平台限约束:大多数软件都会有平台限制,需提前明确这些限制。
  4. 可修改性:需要考虑修改软件所需的工作量。提前预知修改带来的工作量,可以帮助客户更有效地规划项目时间。
  5. 可移植性需求和能力:思考软件在不同平台运行的难易程度,以及适用的硬件和操作系统,还需要考虑软件是否会与其他程序产生冲突。
  6. 可靠性:需要考虑软件发生错误的频率和后果,以及检测错误和修复错误的手段。
  7. 安全性:关乎系统保护和数据保护的需求,例如破解系统的难易程度以及如何降低这些风险。
  8. 可用性:指用户体验,例如学习和操作系统的难度,实际使用软件可能出现的问题或者困难。
  9. 合法性:涉及到的法律问题,例如数据隐私和知识产权。

不同项目的需求会有所不同,常见的需求类别包括: 系统的可用性(系统是否易于使用)、容量(系统能处理多少任务或用户)、可靠性(系统的稳定性或故障率)和安全性(系统防止非法访问或攻击的能力)。可先从这些基本的需求类别着手,逐渐扩展到其他需求领域,最终构建出属于自己的新产品开发项目需求模板。

四、功能性需求和非功能性需求的区别?

功能性需求和非功能性需求都是软件开发的重要组成部分,关注点不同:

  1. 功能性需求(Functional Requirements): 这些需求关注软件应执行的具体功能或行为。例如,一个电子商务网站的功能性需求可能包括用户能够浏览产品目录、添加商品到购物车、进行购物结算等。功能性需求通常以用户故事、用例或系统功能列表的形式进行文档化,这些需求是用户或系统需要完成的具体任务。
  2. 非功能性需求(Non-Functional Requirements): 这些需求关注系统的质量、性能或约束。它们描述了系统应如何工作,而不是系统应该做什么。例如,一个电子商务网站的非功能性需求可能包括系统必须能够处理高并发访问(性能需求)、必须有良好的用户界面(可用性需求),或必须遵循某些数据安全标准(安全需求)。非功能性需求有时也被称为系统属性、质量属性或系统约束。

两者都是必不可少的,功能性需求解释了系统应该执行的任务,而非功能性需求解释了完成这些任务的方式、限制和其他期望。

五、什么是非功能性需求文档?

非功能性需求文档是软件需求规格说明(SRS文档)的关键组成部分。SRS描述了软件应具备的性能、约束特性及其实现方式,定义了用户对产品的性能、可靠性、安全性等方面的需求。

一份标准的SRS通常会包含以下部分:

序言:对系统进行简要概览,提供相关的背景信息,对需要提前定义的术语进行阐释。 总体描述:阐述项目的全局目标、商业价值及项目愿景。 详细需求:这部分明确规定了系统所需的特定属性、功能要求,以及与之相关的数据库需求等。

六、追踪和管理非功能性需求的模版

在整个软件和硬件开发生命周期中,团队需要共同参与定义功能性和非功能性需求。如果使用的工具各不相同,就会影响团队协作。统一化的需求管理方式能够提高效率,增强协作能力,确保团队开发出高质量、合规的产品。

使用统一需求管理方案的好处:

  • 单一的真实数据源:团队成员能够共享相同的信息和数据,整个产品开发周期内信息的透明度较高。
  • 实时更新的优点:可实时了解所有开发团队的进展,随时沟通,有助于团队做出更明智的决策,增强协作能力。
  • 强大的可视化能力:我们可以看到测试如何追溯到需求,这样有助于提升产品质量和规范性。
  • 复用已验证的需求:可以重用已验证过的需求,在不同产品上复制验证过的功能。

统一的需求管理平台(如PingCode等)可帮助我们更有效地定义和处理非功能性需求,提高产品开发效率。所有数据、对话和决策都可被集中在同一个系统中,确保了信息的一致性和准确性,有助于减少误解和混淆。统一的需求管理平台也可以避免重复输入数据或者重复讨论同一个问题,更好地跟踪项目的进度,避免错过重要的时间节点,可极大提高客户对产品的满意度。

需求管理指南: 

需求管理: 需求管理主要内容  |  需求管理的重要性  |  采用敏捷方法进行需求管理  |  如何克服需求管理的 5 大挑战  |  更多 

需求编写: 功能需求的示例和模板  |  采用 EARS 方法来改进需求工程  |  如何编写一份优秀的产品需求文档(PRD) |  功能性需求与非功能性需求的区别  |  有效需求的特征  |  更多 

需求收集和管理流程: 需求工程概述  |  产品团队的需求分析指南  |  敏捷产品团队的 11 种需求收集技巧  |  定义和实施需求基线  |  更多  需求的可追溯性: 什么是需求可追溯性  |  可追溯性在现代产品和系统开发中的关键作用  |  如何创建和使用需求追溯矩阵  |  更多 

需求确认和验证: 产品团队的需求验证和确认  |  更多 

需求管理领域文章:

 做好需求分析的4大关键认知  |  盘点国内9款热门需求管理系统  |  构建产品路线图的方法与工具  |  做好需求优先级判断的7种主流模型  |  采用敏捷方法进行需求管理  | 更多

相关文章:

什么是非功能性需求,它们如何影响产品开发?

我们在选购新车时,会预设一些选购的标准,比如GPS导航必须能够保存目的地,或者必须要买黑色的车。我们可能下意识以为这些是功能性需求,但实际上这些特性都是与用户体验相关的非功能性需求。 一、什么是非功能性需求(NFR)? 非功…...

Oracle jdk8 exe->zip

一、背景 目前Oracle网站对应jdk8安装windows仅存在exe安装包,对于某些用户一台机器上对应jdk版本需动态切换,故需使用zip版本jdk,更加方便,本文介绍如何从jdk对应exe提取zip。 二、步骤 下载jdk8对应exe安装包;使用…...

Android 命令行如何运行 JAR 文件

​ 最近有位老哥问了一个问题,说如果将java的jar文件在Android中执行?这个其实很简单的一个问题,直接写个App放里面不就可以了么?但是人家说没有App,直接使用命令行去运行。说明这个需求的时候,把我给整懵了…...

5.4 webrtc的线程

那今天呢?我们来了解一下webrtc中的threed,首先我们看一下threed的类,它里边儿都含了哪些内容?由于threed的类非常大啊,我们将它分成两部分。 那第一部分呢,是我们看threed的类中都包含了哪些数据之后呢&a…...

vscode | linux | c++ intelliense 被弃用解决方案

每日一句,vscode用的爽是爽,主要是可配置太强了。如果也很会研究,可以直接去咸鱼接单了 废话少说,直接整。 用着用着说是c intelliense被弃用,很多辅助功能无法使用,像查看定义、查看引用、函数跳转、智能提…...

HPE服务器常见报错信息以及解决方案

General controller issues 常规控制器问题 Controllers are no longer redundant 控制器不再冗余 HPE Dynamic Smart Array B140i drives are not found when RAID mode is disabled 禁用 RAID 模式时找不到 HPE 动态智能阵列 B140i 驱动器 Data located on drives accessed i…...

尚硅谷宋红康MySQL笔记 3-9

我不会记录的特别详细 大体框架 基本的Select语句运算符排序与分页多表查询单行函数聚合函数子查询 第三章 基本的SELECT语句 SQL分类 这个分类有很多种,大致了解下即可 DDL(Data Definition Languages、数据定义语言),定义了…...

Leetcode.2337 移动片段得到字符串

题目链接 Leetcode.2337 移动片段得到字符串 rating : 1693 题目描述 给你两个字符串 start 和 target ,长度均为 n n n 。每个字符串 仅 由字符 L、R 和 _ 组成,其中: 字符 L 和 R 表示片段,其中片段 L 只有在其左侧直接存在一…...

【vue】更改角色权限后,实现页面不刷新更改其可展示的导航菜单

登入的角色本身属于领导级别(集团权限),没有下级的不同权限: 切换不同身份(公司),以获得相应部门的不同导航菜单及权限 这里实现:更改角色权限后,实现页面 不刷新 更改…...

【G-LAB】网络工程师常用排错命令详细版

网络工程师在日常配置中难免出现各种配置错误,比如接口地址配错、掩码位数配错、接口忘记no shutdown。除去这些基础错误,在配置各种路由选择协议时也会因为网络类型、邻居类型、区域和路由器层级等各种问题使邻居无法建立、路由无法传递进而导致网络不通…...

Linux 桌面版关闭GUI桌面环境

持久打开和关闭 通过CtrlAltF1-F6快捷键进入命令行界面 执行以下命令,持久关闭Ubuntu桌面版的GUI环境: sudo systemctl set-default multi-user.target执行以下命令,持久开启Ubuntu桌面版的GUI环境 通过CtrlAltF7快捷键进入GUI界面 sudo s…...

ChatGPT能代替搜索引擎吗?ChatGPT和搜索引擎有什么区别?

ChatGPT和搜索引擎是两种在信息获取和交流中常用的工具,ChatGPT是一种基于人工智能技术的聊天机器人,而搜索引擎是一种在互联网上搜索信息的工具。尽管它们都是依托互联网与信息获取和交流有关,部分功能重合,但在很多方面存在着明…...

PHP海外代购管理系统mysql数据库web结构apache计算机软件工程网页wamp

一、源码特点 PHP 海外代购管理系统是一套完善的web设计系统,对理解php编程开发语言有帮助,系统具有完整的源代码和数据库,系统主要采用B/S模式开发。 代码下载 https://download.csdn.net/download/qq_41221322/88229435 论文 https://…...

游戏反外挂方案解析

近年来,游戏市场高速发展,随之而来的还有图谋利益的游戏黑产。在利益吸引下,游戏黑产扩张迅猛,已发展成具有庞大规模的产业链,市面上游戏受其侵扰的案例屡见不鲜。 据《FairGuard游戏安全2022年度报告》数据统计&…...

基于郊狼算法优化的BP神经网络(预测应用) - 附代码

基于郊狼算法优化的BP神经网络(预测应用) - 附代码 文章目录 基于郊狼算法优化的BP神经网络(预测应用) - 附代码1.数据介绍2.郊狼优化BP神经网络2.1 BP神经网络参数设置2.2 郊狼算法应用 4.测试结果:5.Matlab代码 摘要…...

【腾讯云 TDSQL-C Serverless 产品测评】全面测评TDSQL-C Mysql Serverless

全面测评TDSQL-C Mysql Serverless 文章目录 全面测评TDSQL-C Mysql Serverless前言什么是TDSQL-C Mysql Serverless初始化 TDSQL-C Mysql Serverless新建数据库建立数据表开启外网访问 兼容性SQL文件 导入导出navicat 直接在线传输 构建测试环境准备Python测试脚本准备 Jmeter…...

Qt应用开发(基础篇)——纯文本编辑窗口 QPlainTextEdit

一、前言 QPlainTextEdit类继承于QAbstractScrollArea,QAbstractScrollArea继承于QFrame,是Qt用来显示和编辑纯文本的窗口。 滚屏区域基类https://blog.csdn.net/u014491932/article/details/132245486?spm1001.2014.3001.5501框架类QFramehttps://blo…...

数据结构-->栈

💕休对故人思故国,且将新火试新茶,诗酒趁年华💕 作者:Mylvzi 文章主要内容:详解链表OJ题 前言: 前面已经学习过顺序表,链表。他们都是线性表,今天要学习的栈也是一种线…...

强训第36天

C D C 193--1100 0001 194--1100 0010 196--1100 0100 198--1100 0110 能包括全部的且最小的为 1100 0xxx xxx为主机号,站三位 B MAC地址是绑定网卡的,全球唯一 D A C D IP网段 17为网络号 所以是 40.15.1aaa aaa(7位主机号).0 因为要划分2个子网 所以…...

PyTorch bug记录

1、RuntimeError: Input type (torch.FloatTensor) and weight type (torch.cuda.FloatTensor) should be the same 这个错误是因为模型的权重是在GPU上,但是输入数据在CPU上。在PyTorch中,Tensor的类型和所在的设备(CPU或GPU)需…...

【大模型RAG】拍照搜题技术架构速览:三层管道、两级检索、兜底大模型

摘要 拍照搜题系统采用“三层管道(多模态 OCR → 语义检索 → 答案渲染)、两级检索(倒排 BM25 向量 HNSW)并以大语言模型兜底”的整体框架: 多模态 OCR 层 将题目图片经过超分、去噪、倾斜校正后,分别用…...

大话软工笔记—需求分析概述

需求分析,就是要对需求调研收集到的资料信息逐个地进行拆分、研究,从大量的不确定“需求”中确定出哪些需求最终要转换为确定的“功能需求”。 需求分析的作用非常重要,后续设计的依据主要来自于需求分析的成果,包括: 项目的目的…...

css的定位(position)详解:相对定位 绝对定位 固定定位

在 CSS 中,元素的定位通过 position 属性控制,共有 5 种定位模式:static(静态定位)、relative(相对定位)、absolute(绝对定位)、fixed(固定定位)和…...

相机Camera日志分析之三十一:高通Camx HAL十种流程基础分析关键字汇总(后续持续更新中)

【关注我,后续持续新增专题博文,谢谢!!!】 上一篇我们讲了:有对最普通的场景进行各个日志注释讲解,但相机场景太多,日志差异也巨大。后面将展示各种场景下的日志。 通过notepad++打开场景下的日志,通过下列分类关键字搜索,即可清晰的分析不同场景的相机运行流程差异…...

【Java_EE】Spring MVC

目录 Spring Web MVC ​编辑注解 RestController RequestMapping RequestParam RequestParam RequestBody PathVariable RequestPart 参数传递 注意事项 ​编辑参数重命名 RequestParam ​编辑​编辑传递集合 RequestParam 传递JSON数据 ​编辑RequestBody ​…...

3403. 从盒子中找出字典序最大的字符串 I

3403. 从盒子中找出字典序最大的字符串 I 题目链接:3403. 从盒子中找出字典序最大的字符串 I 代码如下: class Solution { public:string answerString(string word, int numFriends) {if (numFriends 1) {return word;}string res;for (int i 0;i &…...

2023赣州旅游投资集团

单选题 1.“不登高山,不知天之高也;不临深溪,不知地之厚也。”这句话说明_____。 A、人的意识具有创造性 B、人的认识是独立于实践之外的 C、实践在认识过程中具有决定作用 D、人的一切知识都是从直接经验中获得的 参考答案: C 本题解…...

C++.OpenGL (14/64)多光源(Multiple Lights)

多光源(Multiple Lights) 多光源渲染技术概览 #mermaid-svg-3L5e5gGn76TNh7Lq {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-3L5e5gGn76TNh7Lq .error-icon{fill:#552222;}#mermaid-svg-3L5e5gGn76TNh7Lq .erro…...

【JavaSE】多线程基础学习笔记

多线程基础 -线程相关概念 程序(Program) 是为完成特定任务、用某种语言编写的一组指令的集合简单的说:就是我们写的代码 进程 进程是指运行中的程序,比如我们使用QQ,就启动了一个进程,操作系统就会为该进程分配内存…...

Kubernetes 网络模型深度解析:Pod IP 与 Service 的负载均衡机制,Service到底是什么?

Pod IP 的本质与特性 Pod IP 的定位 纯端点地址:Pod IP 是分配给 Pod 网络命名空间的真实 IP 地址(如 10.244.1.2)无特殊名称:在 Kubernetes 中,它通常被称为 “Pod IP” 或 “容器 IP”生命周期:与 Pod …...