[架构之路-102]:《软件架构设计:程序员向架构师转型必备》-12-粗粒度“软件架构的功能模块”划分,架构师必备基础技能
Posted 文火冰糖的硅基工坊
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了[架构之路-102]:《软件架构设计:程序员向架构师转型必备》-12-粗粒度“软件架构的功能模块”划分,架构师必备基础技能相关的知识,希望对你有一定的参考价值。
第12章 粗粒度“功能模块”划分
备注:
(1)功能划分的基本原则:
高内聚、低耦合
每个子系统、子模块可以独立设计
(2)划分方法
功能化
水平切分
垂直切分
分层
接口
12.1 功能树
12.1.1 什么是功能树
同一层次的功能之间具有互补性、互斥性,不能相互包含或重叠。
功能树是一种逐步功能分解的展现。
12.1.2 功能分解(需求)≠结构分解(架构)
备注:
功能树:是用于描述需求的,是由需求工程师完成。
功能模块结构图:是用于描述软件 架构的,是由架构师完成的。
12.2 借助功能树(需求),划分粗粒度“功能模块”(架构)
12.2.1 核心原理:从“功能组”到“功能模块”
从需求层面的“功能组”到软件架构的“功能模块”,之间是有一个鸿沟,这个鸿沟就是业务领域的问题域到计算机领域的设计域。
把多个相似的、相关联的功能,组合成一个功能组,对功能组进行抽象、凝聚、汇总,就得到“功能模块”。
需求层面的“功能组”可以通过功能树表达,也可以通过用例图表达,如下图所示:
在上图中,相类似的功能需求组,整合成一个架构上的功能模块,实现软件架构的高内聚、低耦合。
具体实施步骤如下:
12.2.2 第1步:获得功能树
12.2.3 第2步:评审功能树
功能需求的本质:为完成客户或用户的某一个目标,很显然,在上图中,金额计算和按键处理,都不属于功能需求,都不属于用户的某个目标,它属于实现步骤,是一个某个功能实现众多步骤的一部分。
12.2.4 第3步:粗粒度“功能模块”划分
至此,获得的功能需求,现在可以基于功能需求,进架构设计:划分“软件功能模块”。
12.3 实际应用(9)——对比MailProxy案例的4种模块划分设计
12.3.1 设计
12.3.2 设计的优点、缺点
12.4 实际应用(10)——做总体,要提交啥样的“子系统划分方案”
备注:
架构必须时代码结构的体现,是业务需要和软件代码之间的桥梁。
一方面,它要体现业务功能需求,另一方面,他要体现软件的框架,软件会基于该框架进一步的细化代码实现。
感悟:架构师是用户与程序员的桥梁
架构(架构师):必须站在程序员的角度,它描述的是软件系统的架构需要,只有站在程序的角度,程序员才能知道如何基于架构实现软件系统。
需求(需求分析师):必须站在用户的角度,它描述的用户对目标系统的业务需求,只有站在客户的角度,客户才能知道未来实现的软件系统是满足自己业务需求的。
架构师:一脚站在用户的角度,思考用户的需求;另一脚站在程序的角度,思考实现用户业务需要软件的架构。架构师利用自己的大脑中的知识、经验把用户的需求,转换成软件的架构,程序员根据软件的架构,用编程语言和代码实现软件系统。
以上是关于[架构之路-102]:《软件架构设计:程序员向架构师转型必备》-12-粗粒度“软件架构的功能模块”划分,架构师必备基础技能的主要内容,如果未能解决你的问题,请参考以下文章
[架构之路-94]:《软件架构设计:程序员向架构师转型必备》-4-软件架构设计的通用过程
[架构之路-100]:《软件架构设计:程序员向架构师转型必备》-10-细化架构设计
[架构之路-92]:《软件架构设计:程序员向架构师转型必备》-2-解析软件架构的概念
[架构之路-92]:《软件架构设计:程序员向架构师转型必备》-2-解析软件架构的概念