面向对象的需求分析和设计(一)

toc

1. 引言

前一篇文章《我对需求分析的理解》提到了面向对象分析和设计,正好最近又重新有重点的读了谭云杰著的《Think in UML》,感觉有必要写把书中一些核心内容观点以及自己的想法整理出来,一是方便自己日后的复习,另外也能和大家一起交流学习。以下分别从用例驱动、业务需求分析、系统分析几个方面进行分享。

2. 用例驱动

用例驱动(UDD)是软件设计的流行的方法,是以"用例"为核心,开展业务和系统的需求分析、设计工作。那什么是用例,用例是与人(参与者)交互的,提供可观测的有意义的结果的一系列活动的集合。用例是把现实世界(人、事、物、规则)捕获下来的一种方法。以下为用例的构成。

用例的特征:

1、用例是相关对独立的

2、用例的执行结果对参与者来说是可观测的有意义的。

3、用例总是由一个参与者发起的。

4、用例必然是以动宾短语形式出现的。

5、一个用例就是一个需求单元、分析单元、设计单元、开发单元、测试单元,甚至部署单元。

3. 业务需求分析

业务需求分析包括业务建模和概念建模两部分。

3.1. 业务建模

一个完整的业务模型包括以下内容:业务用例视图、业务用例场景、业务用例规约、业务对象模型 、业务用例实现视图、业务用例实现场景。

3.1.1. 业务用例视图
3.1.2. 业务用例场景
3.1.3. 业务用例规约
3.1.4. 业务对象模型
3.1.5. 业务用例实现视图
3.1.6. 业务用例实现场景

3.2. 概念建模

概念模型是针对业务需求中的关键业务(是指撑起客户整个业务架构的主线业务)进行建模,即对关键的业务用例进行分析,建立概念模型和业务架构。概念建模具体包括概念用例、概念用例场景、概念用例对象、分析(模型)场景、业务架构、系统原型。

3.2.1. 概念用例
3.2.2. 概念用例场景
3.2.3. 概念用例对象
3.2.4. 分析(模型)场景
3.2.5. 业务架构
3.2.6. 系统原型

通过概念模型的建立,获得了对需求较为深刻的理解、核心业务的关键概念,建立了业务架构,同时也初步确定了软件架构。此时我们可以采用验证型原型的方法建立系统原型。

4. 系统需求分析

4.1. 系统建模

系统建模包括系统用例(简称用例)、用例场景、用例规约、对象模型、用例实现、用例实现场景。

4.1.1. 系统用例
4.1.2. 用例场景
4.1.3. 用例规约
4.1.4. 对象模型

如果有概念用例对象模型和业和业务对象模型,这里可以直接使用

4.1.5. 用例实现
4.1.6. 用例实现场景
4.1.7. 分析(模型)场景

同概念建模的分析(模型)场景。

4.2. 非功能需求分析

包括对性能、安全、可用性等进行分析。

5. 最后

以上的内容按照业务需求分析、系统需求分析这两个步骤进行了整理,可以在后续分析设计时参考使用。进一步的系统设计可以按照Zachman框架模型等进行总体设计和详细设计。要掌握一种业务知识,按照用例驱动为方法,理清什么"人"用什么"规则"做什么"事"产生什么"物",我想也算是基本熟悉业务知识了。

相关推荐
workflower16 小时前
如何使用设计模式-误区
java·开发语言·设计模式·集成测试·软件工程·需求分析·软件需求
中小企业实战军师刘孙亮2 天前
什么是增长陷阱?中小企业“增长陷阱”破局指南-佛山鼎策创局破局增长咨询
职场和发展·新媒体运营·创业创新·需求分析·内容运营
黄焖鸡能干四碗4 天前
企业数据架构、应用架构、技术架构设计方案(PPT文件)
大数据·运维·数据库·安全·架构·需求分析
锁匙isthekey7 天前
VBA 售后任务信息查询
需求分析
测试者家园8 天前
从需求文档到测试点:利用大模型实现需求理解的自动化
软件测试·自动化·llm·需求分析·持续测试·智能化测试·功能点
中小企业实战军师刘孙亮8 天前
农贸批发市场招商难?从卖摊位变经营赋能破局-佛山鼎策创局破局增长咨询
职场和发展·新媒体运营·创业创新·需求分析·内容运营
测试_AI_一辰10 天前
AI系统到底怎么测?一套六层测试框架(Agent案例)
人工智能·功能测试·需求分析·ai编程
弹简特11 天前
【测试基础】03-软件测试需求分析及常见控件的测试点
功能测试·需求分析
黄焖鸡能干四碗15 天前
业务数据中台技术方案(PPT)
大数据·数据库·人工智能·安全·需求分析
rgb2gray16 天前
论文详解 | HDAM:破解 MAUP 的城市出行需求分析新方法,实现关键驱动精准识别
人工智能·python·llm·大语言模型·需求分析·多模态·maup