第3章-需求 3.1需求的概念

news2025/1/23 7:23:36

产品开发的需求阶段是指立项完成之后,根据立项计划书的任务内容,对任务进行目标分解,形成需求文档,确认项目需求分解到相关责任人或部门。在需求阶段,需要一名具备专业技能和项目经验的工程师来把控整体需求和需求细节。

从整个需求管理的流程角度来看,一般遵循需求收集→需求分析→需求分配→需求实现→需求验证这个过程。需求管理阶段的流程如图3.1所示。
在这里插入图片描述

3.1需求的概念

    • 3.1需求的概念
      • 常见的需求概念
      • 客户需求
      • 原始需求
      • 产品需求
      • 系统需求
      • 功能需求
      • 非功能需求
      • 性能需求
      • 需求分类与管理

3.1需求的概念

需求,也就是用户对需求的描述。这里有两点需要注意,一是要收集来自用户的客观需求,所谓客观,就是产品经理不能引导用户说出自己的需求。二是确保需求描述的完整性,这种需求发生在什么场景,用户的具体需要是什么。需求一定是和场景结合的,脱离了具体场景的需求也就丧失了其价值。

常见的需求概念

下面介绍一些常见的需求概念。
业务需求表示组织或客户高层次的目标。业务需求通常来自项目投资人、购买产品的客户、实际用户的管理者、市场营销部门或产品策划部门。业务需求描述了组织为什么要开发一个系统,即组织希望达到的目标。使用前景和范围文档来记录业务需求,这份文档有时也被称作项目轮廓图或市场需求文档。业务需求通常代表的是产品方向,而不是具体的需求。有的企业讲的战略需求,是业务需求的另外一个说法。

笔者在华为做监控安防产品的时候,海康威视、大华已经占得先机,如何实现突破?当时项目的指导思想是“在品质方面胜出,要做监控安防领域的苹果”,占领技术制高点、产品制高点,避免同质化,避免陷入价格战。那么在这款产品的市场定位上,定义为“高端园区”,所以在特殊功能、性能指标方面,追求极致;而在成本、复杂度上面做出妥协。这款产品因为避开同质化产品,可以通过高价获得更高利润率,并且可以在很多项目中实现控标。

用户需求描述的是用户的目标,用户对产品的要求。用例、场景描述和事件、响应表都是表达用户需求的有效途径,也就是说用户需求描述了用户能使用系统来做些什么。用户需求也不能直接变成产品需求,这中间需要对用户需求做进一步的分析、判断。对于用户需求,千万不要臆想,把自己当作用户。换位思考是好的,但是开发人员往往不具备客户的行业经验,或者不具备用户使用产品的场景,所以用主观意识去使用和认知产品,往往换位不成功,臆想不符合客户需要的原本的模样。

客户需求

客户需求:描述的是客户(为产品买单的人)提出来的需求。对于某些行业来说,例如运营商核心侧设备,客户需求往往就是用户需求,因为客户长期从事相关产品的使用者,属于专业人员,专业能力较强,而且产品附加值高,往往配套专业的培训和教材。但也有相当多的产品,客户和用户并不同,例如儿童玩具、宠物食品等,这就需要兼顾客户需求和用户需求。

原始需求

原始需求:这是描述需求状态维度的一种叫法,常常也被叫作初始需求,是指“未经过任何加工和修改的需求”,业务需求、用户需求、客户需求都属于原始需求。

产品需求

产品需求:产品需要实现的需求,是业务需求、用户需求、客户需求等原始需求的打碎、重组,并不是简单的翻译转换,而是了解全局后的一种重新定义和升华。用户需求到产品需求的转换,一般由产品经理或者系统工程师牵头完成输出。

系统需求

系统需求:用于描述包含多个子系统的产品(系统)的顶级需求。系统可以只包含软件系统,也可以既包含软件又包含硬件子系统。人也可以是系统的一部分。因此某些系统功能可能要由人来承担,最终决定市场对产品的综合评价是否满意。

功能需求

功能需求:必须在产品中实现的功能,用户利用这些功能来完成任务,满足业务需求。功能需求有时也被称作行为需求,因为习惯上总是用“应该”对其进行描述:“系统应该发送电子邮件来通知用户已接受其预定。”

非功能需求

非功能需求:除了功能需求外,我们还常听到一些非功能需求,例如可制造性需求、可服务性需求等跟需求相关的概念,这些都是从不同维度对需求的描述。因此不论是什么需求,我们都应该关注隐藏在这些需求背后的原因,才更容易去权衡各个需求的优先级,更好地进行取舍和排序,使产品在整体上达到最优。

性能需求

性能需求:在实现产品功能的基础上,系统需要达到的性能。可简单地理解为响应速度要快,容量要大等。

需求分类与管理

需求分类如图3.2所示。

在这里插入图片描述
硬件需求管理就是通过需求采集、需求分析、需求筛选及需求管理的一系列过程,挖掘客户所描述需求背后的真实诉求和需要解决的问题,经过需求的转化,把原始需求变成产品的功能需求后,才能得到产品的实现目标。

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

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

相关文章

创新培养:汽车零部件图像分割

汽车零部件图像分割系统源码&数据集分享 [yolov8-seg-C2f-DCNV3&yolov8-seg-C2f-SCcConv等50全套改进创新点发刊_一键训练教程_Web前端展示] 1.研究背景与意义 项目参考ILSVRC ImageNet Large Scale Visual Recognition Challenge 项目来源AAAI Glob…

关于git使用的图文教程(包括基本使用,处理冲突问题等等)超详细

目录 用户签名,初始化git git提交流程图 提交到本地库 版本穿梭 分支操作 分支合并冲突 团队协作 github的使用 推送代码 克隆 拉取代码 团队协作冲突 团队协作之分支管理 推送分支到分支: 拉去远程库分支到本地库: 本地删除远程分支&am…

Linux kernel 堆溢出利用方法(二)

前言 本文我们通过我们的老朋友heap_bof来讲解Linux kernel中off-by-null的利用手法。在通过讲解另一道相对来说比较困难的kernel off-by-null docker escape来深入了解这种漏洞的利用手法。(没了解过docker逃逸的朋友也可以看懂,毕竟有了root权限后&a…

【算法一周目】双指针(1)

目录 1.双指针介绍 2.移动零 解题思路 C代码实现 3.复写零 解题思路 C代码实现 4.快乐数 解题思路 C代码实现 5.盛水最多的容器 解题思路 C代码实现 1.双指针介绍 常见的双指针有两种形式,一种是对撞指针,一种是快慢指针。 对撞指针&#x…

VS2022项目配置笔记

文章目录 $(ProjectDir)与 $(SolutionDir) 宏附加包含目录VC目录和C/C的区别 $(ProjectDir)与 $(SolutionDir) 宏 假设有一个解决方案 MySolution,其中包含两个项目 ProjectA 和 ProjectB,目录结构如下: C:\Projects\…

万字长文解读机器学习——决策树

🌺历史文章列表🌺 机器学习——损失函数、代价函数、KL散度机器学习——特征工程、正则化、强化学习机器学习——常见算法汇总机器学习——感知机、MLP、SVM机器学习——KNN机器学习——贝叶斯机器学习——决策树机器学习——随机森林、Bagging、Boostin…

Kotlin约束泛型参数必须继承自某个父类

Kotlin约束泛型参数必须继承自某个父类 open class SuperData { }class DataA : SuperData {constructor() {println("DataA constructor")} }class DataB : SuperData {constructor() {println("DataB constructor")} }fun <T : SuperData> myfun(p…

Spring挖掘: (事务篇)

谈到事务,我们就绕不开事务的ACID四大特性,我们先来简单介绍一下何为事务 一. 概念 事务是数据库操作的最小工作单元&#xff0c;作为单个逻辑工作单元执行的一系列操作。这些操作作为一个整体一起向系统提交&#xff0c;要么都执行、要么都不执行。事务是一组不可再分割的操作…

Information Server 中共享开源服务中 kafka 的__consumer_offsets目录过大清理

1,11.7新版本的 IBM InfoSphere Information Server 将 Apache Kafka、Solr 和 ZooKeeper 安装在<ISHOME>服务层的 /shared-open-source 目录中。 默认情况下&#xff0c;共享开源中的 Kafka 对 __consumer_offsets 主题使用“压缩”日志清理策略&#xff0c;这可能会导…

Linux系统程序设计--2. 文件I/O

文件I/O 标准C的I/O FILE结构体 下面只列出了5个成员 可以观察到&#xff0c;有些函数没有FILE类型的结构体指针例如printf主要是一些标准输出&#xff0c;因为其内部用到了stdin&#xff0c;stdout&#xff0c;stderr查找文件所在的位置:find \ -name stat.h查找头文件所…

linux网络的基本设置

1、查看网络接口信息 ip a/ip addr #简略的查看网络接口信息 ifconfig #只显示当前活跃的设备 ifconfig -a #实现当前主机的所有网络设备&#xff0c;包括未运行的设备 rootubuntu1:~# ifconfig ens33:flags4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500 设备名…

利用AI制作《职业生涯规划PPT》,10分钟完成

职业生涯规划是大学生活中非常重要的一环。通过制定职业规划&#xff0c;你能够明确未来的职业目标、认清自身的优劣势&#xff0c;进而制定切实可行的计划&#xff0c;以便顺利踏上职业发展的道路。而制作一份精美的职业生涯规划PPT&#xff0c;能有效帮助你在面试、职业规划报…

【数据结构与算法】希尔排序(直接插入排序)

大家好&#xff0c;我是小卡皮巴拉 文章目录 目录 引言 一.直接插入排序的基本思想 二. 直接插入排序算法解析 详细版本的算法思想解析 算法思想提炼 实现代码 画图刨析 三. 直接插入排序的特性 复杂度分析 稳定性分析 四. 希尔排序的基本思想 五. 希尔排序算法解…

RK3568 Android12跳过认证 预置谷歌服务GMS

在Rom开发中需要发布海外版本时基本都需要内置google服务,而规范方式集成的话都需要设备进行认证,获取google应用签名等非常复杂的一套流程,一般大厂才有这些资质和资源,这里介绍一种非常规方式集成GMS,跳过设置认证流程,在RK3568 android12环境亲测有效。 谷歌全家桶中…

深度学习之卷积问题

1 卷积在图像中有什么直观作用 ​ 在卷积神经网络中&#xff0c;卷积常用来提取图像的特征&#xff0c;但不同层次的卷积操作提取到的特征类型是不相同的&#xff0c;特征类型粗分如表1所示。 ​ 表1 卷积提取的特征类型 卷积层次特征类型浅层卷积边缘特征中层卷积局部特征深…

Go语言的内置容器

文章目录 一、数组数组的定义数组声明数组特点数组元素修改 二、切片切片声明基于数组创建切片使用make()函数构造切片使用append()为切片动态添加元素\使用copy()复制新的切片数组与切片相互转换 三、Map映射Map定义使用make()函数创建map用切片作为map的值使用delete()函数删…

二叉树的各种操作补充

二叉树的各种操作补充 求二叉树的结点数求二叉树的叶结点数求二叉树的高度求二叉树的第k层结点数查找指定结点层序遍历判断二叉树是否是完全二叉树 我们任然沿用二叉树的基本信息&#xff1a; typedef char BTDataType; typedef struct BinaryTreeNode {BTDataType _data;struc…

Go语言的常用内置函数

文章目录 一、Strings包字符串处理包定义Strings包的基本用法Strconv包中常用函数 二、Time包三、Math包math包概述使用math包 四、随机数包&#xff08;rand&#xff09; 一、Strings包 字符串处理包定义 Strings包简介&#xff1a; 一般编程语言包含的字符串处理库功能区别…

Perfetto中如何使用SQL语句

在使用 Perfetto 分析 Android 性能时&#xff0c;可以通过 Perfetto 提供的内置 SQL 查询来提取和分析不同的性能数据。Perfetto 允许你在 UI 界面或命令行中运行 SQL 查询&#xff0c;提取出 Trace 数据中包含的各种性能信息&#xff0c;比如 CPU 使用率、线程状态、内存分配…

QML项目实战:自定义TextField

目录 一.添加模块 import QtQuick.Controls 1.2 import QtQuick.Controls.Styles 1.4 import QtGraphicalEffects 1.15 二.自定义TextField 1.属性设置 2.输入框设置 3.按钮开关 三.效果 1.readonly为false 2.readonly为true 四.代码 一.添加模块 import QtQuick.…