什么是非功能性需求,它们如何影响产品开发?
我们在选购新车时,会预设一些选购的标准,比如GPS导航必须能够保存目的地,或者必须要买黑色的车。我们可能下意识以为这些是功能性需求,但实际上这些特性都是与用户体验相关的非功能性需求。
一、什么是非功能性需求(NFR)?
非功能性需求是对软件系统的全局性约束,包括但不限于开发成本、运营成本、性能、可靠性、可维护性、可移植性和扩展性等。一个与功能无关,但与可靠性、效率、可用性、可维护性和可移植性等属性相关的需求。
在系统工程和需求工程中,非功能性需求是一个指定可以用来判断系统操作的标准,而不是特定行为的需求。
在描述非功能性需求时常会用到一些副词或修饰语,如“系统应能快速打印发票”,或“系统应在确保信息安全的情况下打印出发票”。
软件的非功能性需求关乎用户体验。忽视这些需求可能会导致项目延期,预算超支,用户满意度降低,也可能会导致项目目标不明确,进而导致产品偏离用户的期望。
非功能性需求弥补了开发者认为客户想要的和客户真正想要的之间的差距。
研究显示,软件开发成本中的60%到80%用于修复产品存在的问题,完善的非功能性需求可以消除约50%到80%的产品缺陷。
既然我们已经知道了非功能性需求的重要性,那么问题来了:如何有效地将非功能性需求融入到产品开发过程中呢?
二、非功能性需求关注产品的”性能”
产品的”性能”包括质量、可靠性、可制造性、可用性、可服务性、可升级性等。
非功能性需求关注用户体验,定义了系统的质量、约束条件或外部接口等方面的要求。如果我们想设计出一个具有可扩展性的系统,仅凭口头描述往往不够清楚,需要将目标具体化,比如:“构建出一个在未来24个月内能够管理至少50,000名用户的系统,以防止系统崩溃对用户造成困扰”。
另外,非功能性需求还可能涵盖以下方面:
- 法律法规或相关规定。
- 定义软件的质量属性。
- 确保关键领域的性能表现,例如可靠性、可用性和可扩展性。
- 提升用户体验,使系统更易于操作,并最大程度地减少返工。
就像购车一样,不同的人获得最佳用户体验所要求的产品特性不同。你可能需要加热座椅,而其他人则可能想要三排座椅。所以,你为项目定义的非功能性需求会根据客户期望而变化。然而,一个可能的非功能性需求类别列表可以作为你的起始点,帮助你思考在你的需求列表中应该包含哪些非功能性需求。
三、非功能性需求的不同类别?
把非功能性需求想象成一种容器,里面装载的是与用户体验密切相关的重要属性。要记住,非功能性需求并不是关于产品将要完成什么任务(那是功能性需求的范畴),而是关于这个项目将要达到的目标或理想状态。
如果你选择了正确的容器并且衡量了正确的事物,那么你就可以放心,你交付的产品会满足客户的期望——因为你已经明确地定义了这些期望。每个人都在同一认知水平上,这在你集中管理你的需求时,会进一步增强。
接下来,让我们看看一些常见的非功能性需求类别:
- 性能和可扩展性:确定所需的响应时间、性能标准和其他与性能相关的属性。系统生成结果的速度有多快?系统在高负荷下的性能如何?
- 操作限制:这部分涉及产品开发过程中必须遵守的特定软件需求、系统需求,以及运行时候的约束。
- 平台限约束:大多数软件都会有平台限制,需提前明确这些限制。
- 可修改性:需要考虑修改软件所需的工作量。提前预知修改带来的工作量,可以帮助客户更有效地规划项目时间。
- 可移植性需求和能力:思考软件在不同平台运行的难易程度,以及适用的硬件和操作系统,还需要考虑软件是否会与其他程序产生冲突。
- 可靠性:需要考虑软件发生错误的频率和后果,以及检测错误和修复错误的手段。
- 安全性:关乎系统保护和数据保护的需求,例如破解系统的难易程度以及如何降低这些风险。
- 可用性:指用户体验,例如学习和操作系统的难度,实际使用软件可能出现的问题或者困难。
- 合法性:涉及到的法律问题,例如数据隐私和知识产权。
不同项目的需求会有所不同,常见的需求类别包括: 系统的可用性(系统是否易于使用)、容量(系统能处理多少任务或用户)、可靠性(系统的稳定性或故障率)和安全性(系统防止非法访问或攻击的能力)。可先从这些基本的需求类别着手,逐渐扩展到其他需求领域,最终构建出属于自己的新产品开发项目需求模板。
四、功能性需求和非功能性需求的区别?
功能性需求和非功能性需求都是软件开发的重要组成部分,关注点不同:
- 功能性需求(Functional Requirements): 这些需求关注软件应执行的具体功能或行为。例如,一个电子商务网站的功能性需求可能包括用户能够浏览产品目录、添加商品到购物车、进行购物结算等。功能性需求通常以用户故事、用例或系统功能列表的形式进行文档化,这些需求是用户或系统需要完成的具体任务。
- 非功能性需求(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)需…...
泛微OA Ecology 安全补丁管理账号配置与实战
1. 泛微OA Ecology安全补丁管理账号配置详解 第一次接触泛微OA Ecology系统的安全补丁管理功能时,我完全没意识到这个看似简单的配置背后藏着这么多门道。直到有次系统被恶意攻击,才发现默认的管理账号存在安全隐患。今天就带大家彻底搞懂这个关键配置&a…...
Simulink与Plecs联合仿真实现三相桥式电路能量双向流动
simulinkplecs联合仿真源件,三相桥式电路,采用母线电压外环与电流内环控制,可整流也可逆变并网,实现能量双向流动,采用SVPWM调制方式。 1.plecssimulink 2.SVPWM 3.双闭环 支持simulink2022以下版本,联系跟…...
黑丝空姐-造相Z-Turbo实战项目:数据库课程设计之AI图库管理系统
黑丝空姐-造相Z-Turbo实战项目:数据库课程设计之AI图库管理系统 最近在带学生做数据库课程设计,发现一个挺有意思的现象:很多同学觉得数据库设计就是建几张表,写几个查询,做完就完了,跟实际应用脱节挺大的…...
2026论文降重神器盘点!毕业论文“AIGC痕迹”怎么破?
【CSDN技术引言:拒绝“开源背调”式的学术翻车】 哈喽各位同行和科研圈的战友们。最近后台私信快炸了,今年这届硕博生仿佛遭遇了“灭顶之灾”。某985高校前天出炉的抽检结果直接把大家看傻了:明明自己逐字逐句手敲的论文,知网查重…...
梦行云软件——溯源系统-》企业方》产品溯源管理》员工管理
梦行云软件——溯源系统-》企业方》产品溯源管理》员工管理 湖南梦辰软件开发有限公司是立足怀化、服务全国的数字化技术服务商。公司拥有19项软件著作权及多项自主知识产权。专注于Web系统、APP与小程序定制开发,提供全链路数字化解决方案。以合规先行与稳定交付为…...
PTA L1-064 AI核心代码:从‘估值一亿’到‘精准实现’的避坑指南
1. 这道题为什么值"一亿"? PTA L1-064被戏称为"估值一亿"的题目,主要因为它在字符串处理中埋了多个隐蔽的坑点。我第一次做这道题时,看着题目要求觉得规则很明确,不就是几个字符串替换吗?结果提交…...
基于springboot的某学院勤工俭学岗位兼职平台设计与实现
目录 技术选型与架构设计核心功能模块划分数据库设计要点关键代码实现示例安全与权限控制测试与部署计划扩展性考虑 项目技术支持源码获取详细视频演示 :文章底部获取博主联系方式!同行可合作 技术选型与架构设计 后端采用SpringBoot框架,集…...
OpenCore Configurator:革新性黑苹果配置工具,让复杂引导设置化繁为简
OpenCore Configurator:革新性黑苹果配置工具,让复杂引导设置化繁为简 【免费下载链接】OpenCore-Configurator A configurator for the OpenCore Bootloader 项目地址: https://gitcode.com/gh_mirrors/op/OpenCore-Configurator 价值定位&#…...
告别C++复杂配置:5分钟在UE5里搞定一个简单的HTTP客户端
告别C复杂配置:5分钟在UE5里搞定一个简单的HTTP客户端 在独立游戏开发和教育领域,快速验证网络交互功能的需求日益增长。无论是从服务器拉取动态配置,还是提交玩家成绩数据,一个轻量级的HTTP客户端往往能大幅提升原型开发效率。传…...
League-Toolkit英雄联盟工具集启动故障解决方案
League-Toolkit英雄联盟工具集启动故障解决方案 【免费下载链接】League-Toolkit 兴趣使然的、简单易用的英雄联盟工具集。支持战绩查询、自动秒选等功能。基于 LCU API。 项目地址: https://gitcode.com/gh_mirrors/le/League-Toolkit League-Toolkit作为一款基于LCU A…...
