用例图这样画,3步让你做需求分析有理有据

之前写《做产品,为什么要画这些图?》,介绍产品常用视图后,一直想深入介绍每一种图的用法,却生怕理解不到位,又不想当文字搬运工,迟迟不敢开写。

这次趁着打磨课程,逼自己猛啃几本书,结合这几年做产品的经历,总算提炼出自己的思路。

我首先要讲的是用例图,用例是UML中最重要的一个元素,后续分析流程、设计功能,都是围绕它展开的。

本文先介绍为什么要画用例图,再为你解读用例图知识,最后用一个案例演示如何画用例图。

做产品前几年,我很少画用例图,直到做数据中台,碰到的需求更复杂,我重翻《大象:ThinkinginUML》找灵感。

读到用例时,我恍然大悟,原来我放着用例这么好的法宝不用,简直暴殄天物。

后来,我从业务调研开始,用用例的分析方法,把业务研究透、描述出来,系统该做成怎样,脑海里渐渐清晰。

当然,并非每个需求都得画用例图,简单的需求完全可以不用牛刀。

用例的设计之初,是希望我们别老在系统内执着功能,而是跳到系统外,以用户的眼光看系统,思考什么情况下给什么人提供什么支持。

如果我们学会了用例图的分析思想,理解它的表达逻辑,至少能试着站在用户的角度去看问题。

开启这种视角,才不会总用晦涩难懂的术语,将用户搞晕,才能用业务方的语言去沟通,真正以用户为中心去获取需求,转化为产品服务。

练习的办法,便是按用例的规则和方法,一点点做,逐渐转变思考的方式。

这让我想起,以前给老妈换手机,要教会她使用,可让我头疼了。

后来,我反思自己,改变策略,只给她讲,她用手机会做的几件事情。

结果,她居然记住了。

发现没?功能描述容易脱离用户使用场景,让人困惑。

所以,我们要从场景出发,围绕用户在具体情况下,要做的事情,告诉他怎么做就好了。

每个讲产品经理的思维方式,都会讲系统思维。可,真能用系统思维去思考的人,可谓凤毛麟角。

究竟什么是系统思维呢?

做产品时,如果只讨论功能,就是孤立地看待产品。

产品脱离了使用者,就没有意义。只有当我们把产品和使用者都考虑进去,才算是系统的思考。

用例的本质,就是将产品和使用者当成一个系统来看。

下面一起看看用例为何物吧。

用例,是UML中用来捕获功能性需求的一种方法,它从不同视角,描述不同角色用系统/产品做什么事,即什么人做什么事。

一个用例,就是参与者为完成某个特定目标的一系列活动或功能的集合。

换句话说,用例是参与者为满足自己的期望,而完成的事情。

所以说,用例不是功能,而是由参与者驱动的,是有明确目标的,是从用户视角看问题的。

比如,人喝水,大致要做拿杯子、倒水、喝这几个动作,人喝水是用例,拿杯子却不是,因为不会有人没有目的只拿杯子。

用例图,由参与者、用例、边界和关系构成。

1)参与者,用小人表示

按官方文档的定义,参与者是在系统外部与系统交互的人或事物,可以是人、部门或系统。

产品面向的用户,也是在系统之外的参与者。

有时,系统内部也有一些人或对象,参与完成业务,这种称之为业务工人,并非参与者,需区分清楚。

2)用例,用椭圆表示

用例,表示参与者为完成某个目标的一系列活动。用例名称,以动宾短语出现,表示参与者做的事情。

用例是业务分析、需求分析、系统分析与设计过程的基本单位,粒度可大可小。

粒度的确定,一直是个难题,没有标准,只能根据实际情况分析。一个大型系统,可能会有上百个用例,一个小产品,也许只有几个用例。

这有2个经验供你参考:

3)边界,用矩形表示

边界将系统内外分开,参与者在外面,用例在里面。边界内的用例,就是系统要实现的事情。

一个系统的好坏,常取决于边界是否清晰,即明确做什么、不做什么。边界内的事,是系统的任务;如没有特定条件推动,系统与外界没有联系。

设计产品时,一出现自相矛盾、疑惑的问题,往往可能是不知不觉偏离了最初的定位,跑到边界外部。

因此,做产品要多回归定位,检查产品有没有越界。一个好的产品,是界限分明的,做什么不做什么从不含糊。

4)关系,用常见的箭头连线

UML中关系挺多的,常用的有关联、包含、扩展、实现四种。

5)用例表,图形之外的文字补充

除了画图,UML中用例图还会写用例表,以描述说明用例,内容包括用例名称、用例描述、参与者、前后置条件、基本流程等。

在UML中,用例图的常见类型,有业务用例图和系统用例图。

1)业务用例图

业务用例图,是从业务的视角,对业务进行描述。即描述没有新系统或产品前,业务是如何进行的。

UML使用业务用例图,旨在把业务描述清楚,发现业务问题和目标,新系统才能更好地解决问题,实现业务目标。

简单需求,很少画业务用例图;复杂需求,用这个思路分析,更好发现业务问题,保证产品需求不跑偏。

2)系统用例图

一般说用例图,默认指系统用例图,它描述参与者使用新系统或产品做什么事,从而实现业务目标。

它是从业务用例分析推导出来的,是新系统的蓝图、开发范围。

从业务用例如何分析、推导出系统用例呢?下面的案例马上讲到。

画图是为了表达、传递信息,当我们画用例图时,本质是在分析业务场景、系统功能性需求,并描述出来。

因此,与其说学如何画用例图,不如说是在学如何分析,用例图只是分析的结果。

下面,我将通过用一个简单的案例,把这个分析过程,一步步展示出来。

以手机话费充值业务为例,假设我们接到一个需求,要开发一个话费充值APP,为用户提供充值服务。

常规做法,接到需求,会想到去调研业务、研究竞品,列出功能结构图,再画流程图,很快就能画原型,写PRD。

对于简单的产品,这么做没问题。但碰到复杂的系统,就得有一套好的分析思路和方法工具。

用例图,可以帮我们从业务场景分析入手,理清业务,逐步推导出系统功能。

具体怎么做呢?我总结了这3步。

这个业务的“人”比较好找,就是普通手机用户。目标,是为了保证手机可用,得充话费。

由此,得出充值话费的几种实现方式,而我们要做一个充值APP,便是实现方式之一。

△充值话费业务用例实现

一个是充值,这个过程不能中断,一断充值就不成功,所以,可以得到一个小目标:充值话费。

一个是查结果,支付完成后,不一定马上有结果,但基本都会成功,这时用户可选择离开;还有一种场景,发现话费快用完了,查什么时候充值的。可见,查看结果目标也相对独立。

有上面的分析,我们可以把两个有完整目标的活动集合,归纳为两个业务用例:充值话费、查看结果。

再把视角缩到充值过程,充值得支付金额,而支付一般是通用的,供其他模块使用,在系统内部看相对独立,可抽出来,作为子用例。

当查看结果时,发现话费并未到账,需要联系客服处理,虽然这不多见,但偶有发生,所以是一个特殊情况下才会发生的支流,可作为扩展用例。

经过从场景到流程的分析,业务用例基本清楚。就到最关键的一步,推导出系统用例。

常用的推导方法有:映射、抽象、拆分、合并和补充等。

这容易被误以为是抄袭。实际上,如今大部分产品功能都类似,很少有完全创新的东西。如能从用例去分析,就知道为什么这个功能要“抄”,哪个不“抄”,“抄”了要不要改,改哪些。

3)拆分、合并,把一些大的用例进行拆解,或小的用例进行合并,合并类似抽象归纳。

这些都是后续系统分析、梳理系统关系、设计系统架构的基础。

为方便说明,我只简化出核心部分,并把子用例合在一起展示。

△充值APP系统用例图

至此,充值APP的系统用例图就出来了。

有这份新系统的蓝图,就可以细化前端APP和管理后台的用例,进而再分析系统流程、系统关系、设计产品功能。

这一路的分析推导下来,再画原型图、写PRD,你自然知道要写什么,设计出来的功能,也更有依据、有逻辑,不容易被人以为是靠拍脑袋的。

用例图的基本用法,到此结束了,看累了吧?没关系,我帮你小结下,记住这几条就够了。

用例是从用户视角去思考的,学会站在用户的角度去看产品,更能理解业务,表达清楚需求。

用例的本质,是场景化思维和系统思维的体现。画图的过程,实际上是在锻炼我们的思维方式。

用例图,由参与者、用例、边界、关联构成,写用例表,更完整。

用例图,常见类型有业务用例图和系统用例图。

1)分析业务场景,找出人、事、物、目标。

2)分析业务流程,细化目标,得出业务用例图。

3)由业务用例图推导出系统用例图。

常用推导方法有:映射、抽象、拆分、合并和补充等。

最后,不是所有需求都要画用例图,视情况而定。

用例作为一种需求分析方法,不管你在是否用到它,关键是理解它的分析思路和表达逻辑。

善用用例,可以提高我们在需求分析、产品设计中的理解、思考和表达能力,确保我们的输出是高效、准确、有理有据的。

THE END
1.优质用例图模板大全!5步详解绘制步骤用例图的常见用途 1、校园卡系统,主要分为管理者用例图和学生参与者用例图。2、图书管理,分析系统中的角色和用例,还涉及读者信息管理、借阅信息管理和图书信息管理等多个方面。3、产品经理必备,借助用例图明确产品的用户特征,产品的功能。用例图通用模板 用例图模板如下图所示,且均可在 亿图图示 中迅速找并且https://baijiahao.baidu.com/s?id=1674253977348339670&wfr=spider&for=pc
2.盐管理系统用例图盐管理系统用例图解析与软考应用二、选课管理系统用例图分析 用例图是软件工程中的一种重要工具,它能够清晰地描述系统与外部实体(如用户)之间的交互关系。在选课管理系统中,主要的用例包括学生选课、教务人员管理课程、系统管理员维护系统等。 1.学生选课用例 学生选课用例是选课管理系统的核心用例之一。学生登录系统后,可以查看课程列表,了解课程的详细https://blog.51cto.com/u_15567955/11188459
3.UML系统分析和设计:用例图故事起点:发起目标查询 故事终点:确认订单(不包含支付) 描述手法:参考 “建模练习” 文档 用“艺龙网”的网上订酒店来模仿建模:(更多信息在艺龙网官网http://www.elong.com/) 图1显系统分析与设计学习笔记(二)用例模型 用例Use Case Use Case(用例)是一个系统分析与设计中非常重要的概念,在使用整个软件https://www.pianshen.com/article/86692001710/
4.需求分析之——用例图需求分析用例图用例图(Use Case Diagram)是由软件需求分析到最终实现的第一步,它描述人们如何使用一个系统。用例视图显示谁是相关的用户、用户希望系统提供什么样的服务,以及用户需要为系统提供的服务,以便使系统的用户更容易理解这些元素的用途,也便于软件开发人员最终实现这些元素。用例图在各种开发活动中被广泛的应用,但是它最常用https://blog.csdn.net/dw_java08/article/details/7580625
5.用例图完全指南:需求分析与系统设计的绝佳工具用例图(Use Case Diagram)是UML中的一种图形化建模工具,用于描述系统功能与外部参与者之间的交互场景。用例图是需求分析和系统设计的重要工具,它能够帮助团队成员更好地理解系统的功能需求和交互流程,从而有效地进行系统设计和开发。本文将全面解析用例图,从定义、用途和作用、应用案例分析以及高效使用技巧,帮助读者深入https://boardmix.cn/article/what-is-use-case-diagram/
6.学生信息管理系统的用例图和图书管理系统系统分析及用例图[通俗易练习二 图书管理系统系统分析及用例图 图书管理系统能够为一定数量的借阅者提供服务。每个借阅者能够拥有唯一标识其存在的编号。图书馆向每一个借阅者发放图书证,图书证中包含每一个借阅者的编号和个人信息。系统通过一个单独的程序为借阅者提供服务,不需要管理人员的干预,这些服务包括提供查询图书信息、查询个人信息服务https://cloud.tencent.com/developer/article/2091279
7.用例图这样画,3步让你做需求分析有理有据建议收藏用例的设计之初,是希望我们别老在系统内执着功能,而是跳到系统外,以用户的眼光看系统,思考什么情况下给什么人提供什么支持。 如果我们学会了用例图的分析思想,理解它的表达逻辑,至少能试着站在用户的角度去看问题。 ?开启这种视角,才不会总用晦涩难懂的术语,将用户搞晕,才能用业务方的语言去沟通https://www.niaogebiji.com/pc/article/detail/?aid=74981
8.软件需求分析复习指南(二)附件图是一个零售系统的用例图,请阅读该用例图,分析该用例图包含了哪些要素,并举例说明该图中的对应要素是什么,不同的关系表达什么含义? 方式:手写答题,拍照上传 五. 顺序图 仔细分析“语音邮箱系统”的“保留语音信息”和“拨打邮箱号”的用例事件流描述,请找出里面的对象,并画出顺序图。 https://developer.aliyun.com/article/1249157
9.需求分析:功能角色分析与用例图对一个系统进行功能和角色方面的梳理和分析,可以采用的比较主流的方法之一就是绘制用例图。用例图是UML的4+1视图中的一种,准确地说就是那个“+1”。用例图是贯穿整个面向对象分析/设计(OOA/D)的核心视图,它描述的是系统到底为用户提供了哪些功能,以及到底是哪些用户在使用这些功能,是沟通用户与技术人员的桥梁。 https://www.jianshu.com/p/8d562fc36d6b
10.UML用例图简单来说,用例图是用于描述行为的图,他用于描述一系列角色(actors)与用例(use case)之间的关系。因此,通过用例图,我们能够知道系统中涉及到的角色、以及每个角色都能通过这个系统做什么。 一般我们描述事件,可能会使用 5W1H 的方式来表达,对应来看,用例图便是从 who&what 的维度来表达设计。 https://zhuanlan.zhihu.com/p/78243709
11.基于UML的信息系统需求分析模型AET摘要:针对目前常用的需求分析方法存在的弊端,提出了一种基于UML的信息系统需求分析模型,该模型提供了一个基于UML信息系统需求分析框架及其应用过程。实践表明,该模型对信息系统开发具有较好的适应性。 关键词:需求分析;统一建模语言;管理信息系统; 用例图 需求分析是软件开发的关键环节,需求分析结果的好坏直接决定软件开发http://www.chinaaet.com/article/95507
12.系统分析师UML用例实战PDF扫描版[27MB]电子书下载系统分析师UML用例实战 目录: 前言 作者简介 第1章绘制用例图 1?1【基础】使用用例的时机 1?2【基础】一睹用例的长相 1?3【基础】绘制用例图 1?4【案例】书店系统 1?5【高级】系统内部启动的用例 1?6【高级】UML风格 1?7【高级】用活动图来抓用例 https://www.jb51.net/books/164915.html
13.超市管理系统小型超市管理系统用例建模,小型超市管理系统交互图建模, 小型超市管理系统类图建模,小型超市管理系统活动图、状态图建模 一、摘要 通过本实验掌握小型应用系统类模型的建立,具体包含如下内容: 1、在用例建模的基础上通过用例分析法和名词分析法寻找类; 2、确定类之间的关系; 3、掌握类图建模的基本步骤; 4、学会使用Rathttps://www.iteye.com/resource/h471507602-10876041
14.uml图书借阅管理系统的用例图(10页)UML图书借阅管理系统的用例图 1.问题描述图书管理系统涉及读者信息管理、借阅信息管理、图书信息管理 等多方面的信息管理,系统的使用对象为图书管理员和读者。他们在 使用系统时,各拥有不同的权限,以完成各白需要的工作。下面对图 书管理系统中主要的业务流程进行简要分析:在图书管理系统中,图书管理员要为每个读者建立https://max.book118.com/html/2021/0728/6223243134003221.shtm
15.基于Python的高校电子文档管理系统根据需求分析和设计思路可以得到系统的用例图, 如图2所示, 将本系统分为项目文档整理、检索与统计、移交接收管理和系统管理4个功能区. 图2 归档系统用例图 (1) “项目文档整理”包含6项子功能: 文档导入(自动导入、人工录入、本地导入), 文档补充, 项目信息补录, 删除文档, 文档格式转换, 文档元数据提取. https://c-s-a.org.cn/html/2021/4/7843.html
16.软考软件设计师知识点精讲之用例图软件设计师1.用例图的元素 用例是一种描述系统需求的方法,使用用例的方法来描述系统需求的过程就是用例建模。在用例图中,主要包括参与者、用例和通信关联三种元素,如图2-1所示。 图2-1用例图中的基本元素 (1)参与者。参与者(角色、动作者、执行者)是指存在于系统外部并与系统进行交互的任何事物,既可以是使用系统的用户,https://www.educity.cn/rk/1773808.html