软件设计的方法论:软件为什么要建模?

简介: 软件设计的方法论:软件为什么要建模?

我们开发的绝大多数软件都是用来解决现实问题的。

通过计算机软件,可以用高效、自动化

的方式去解决现实中低效的、手工的业务过程。

因此软件开发的本质就是在计算机的虚拟空间中根据现实需求创建一个新世界。阿里的工程

师在创造一个“500 平方公里”的交易市场,百度的工程师在创造一个“一万层楼”的图

书馆,新浪微博的工程师在创造“两亿份报纸”,腾讯的工程师在创造“数 10 亿个聊天茶

室和棋牌室”。

现实世界纷繁复杂,庞大的软件系统也需要很多人合作,开发出众多的模块和代码。如何使

软件系统准确反映现实世界的业务逻辑和需求?庞大的软件系统如何能在开发之初就使各个

相关方对未来的软件蓝图有清晰的认知和认可,以便在开发过程中使不同工程师们能够有效

合作,能够让软件的各个模块边界清晰、易于维护和部署?

这个由软件工程师创造出来的虚拟世界,是一个恢弘大气的罗马都城,还是一片垃圾遍地的

棚户区,就看软件工程师如何设计它了,而软件设计的主要过程就是软件建模。

软件建模

所谓软件建模,就是为要开发的软件建造模型。模型是对客观存在的抽象,我们常说的数学

建模,就是用数学公式作为模型,抽象表达事务的本质规律,比如著名的 E = mc2,就是

质量能量转换的物理规律的数学模型。

除了数学公式是模型,还有一些东西也是模型,比如

地图,就是对地理空间的建模。各种图纸,机械装置的图纸、电子电路的图纸、建筑设计的

图纸,也是对物理实体的建模。而软件,也可以通过各种图进行建模。

通过建模,我们可以把握事物的本质规律和主要特征,正确建造模型和使用模型,以防在各

种细节中迷失方向。软件系统庞大复杂,通过软件建模,我们可以抽象软件系统的主要特征

和组成部分,梳理这些关键组成部分的关系,在软件开发过程中依照模型的约束开发,系统

整体的格局和关系就会可控,相关人员从始至终都能清晰了解软件的蓝图和当前的进展,不

同的开发工程师会很清晰自己开发的模块和其他同事工作内容的关系与依赖,并按照这些模

型开发代码。

在软件开发中,有两个客观存在,一个是我们要解决的领域问题,比如我们要开发一个电子

商务网站,那么客观的领域问题就是如何做生意,卖家如何管理商品、管理订单、服务用

户,买家如何挑选商品,如何下订单,如何支付等等。对这些客观领域问题的抽象就是各种

功能及其关系、各种模型对象及其关系、各种业务处理流程。

另一个客观存在就是最终开发出来的软件系统,这个软件系统也是客观存在的,软件由哪些

主要类组成,这些类如何组织构成一个个的组件,这些类和组件之间的依赖关系如何,运行

期如何调用,需要部署多少台服务器,服务器之间如何通信等。

image.gif编辑

所有这两个方面客观存在的抽象,就是我们的软件模型,一方面我们要对领域问题和软件系

统进行分析、设计、抽象,另一方面,我们根据抽象出来的模型开发,实现出最终的软件系

统。这就是软件开发的主要过程。而对领域问题和软件系统进行分析、设计和抽象的这个过

程,我们专门划分出来,就是软件建模与设计。

4+1 视图模型

软件建模比较知名的是 4+1 视图模型,准确地说,4+1 模型不是一种软件建模工具和方

法,而是一种软件建模方法的方法,即建模方法论。

4+1 视图模型认为,一个完整的软件设计模型,应该包括 5 部分的内容:

image.gif编辑

    1. 逻辑视图:描述软件的功能逻辑,由哪些模块组成,模块中包含那些类,其依赖关系如
      何。
    2. 开发视图:包括系统架构层面的层次划分,包的管理,依赖的系统与第三方的程序包。
      开发视图某些方面和逻辑视图有一定重复性,不同视角看到的可能是同一个东西,开发
      视图中一个程序包,可能正好对应逻辑视图中的一个功能模块。
    3. 过程视图:描述程序运行期的进程、线程、对象实例,以及与此相关的并发、同步、通
      信等问题。
    4. 物理视图:描述软件如何安装并部署到物理的服务上,以及不同的服务器之间如何关
      联、通信。
    5. 场景视图:针对具体的用例场景,将上述 4 个视图关联起来,一方面从业务角度描述,
      功能流程如何完成,一方面从软件角度描述,相关组成部分如何互相依赖、调用。
    6. 在机械制图领域,一个立体的零件进行制图设计,必须要画三视图,即正视图、侧视图、俯
      视图,每张图都平面的,但是组合起来就完整地描述了一个立体的机械零件。
    7. 4+1 视图模
      型也是通过多个角度描述软件系统的某个方面的抽象模型,最终组合起来构成一个软件完整
      的模型。

    8. 三视图中,有些部分是重复的,而正是这些重复的部分将机械零件不同视角的细节关联起
      来,使看图者准确了解一个机械零件的完整结构。软件建模的时候也是如此,作为设计者,
      也许你觉得用多个视图描述软件模型会重复,但是阅读你的设计文档的人,正是通过这些重
      复,才将软件的各个部分关联起来,对软件整体形成完整的认识。
      我在前面说 4+1 视图模型是一种方法论的原因,就在于这 5 种视图模型主要指导我们应该
      从哪些方面去对我们的业务和软件建模。而具体如何去建模,如何画模型,则可以使用各种
      建模工具去完成,重要的是这些模型能够构成一个整体,从多个视角完整抽象软件系统的各
      个方面。
      在实践中,通常用来进行软件建模画图的工具是 UML,建模的时候,也不一定要把 5 种视
      图都画出来。因为不同的软件类型其特点和设计关注点各不相同,只要能向相关人员准确传
      递出自己的设计意图就可以了。

    UML 建模

    UML,即统一建模语言,是目前最常用的建模工具,使用 UML 可以实现 4+1 视图模型。

    这个名字的叫法也很有意思。

    所谓统一,指的是在 UML 之前,软件建模工具和方法有很多种,最后业界达成共识,用

    UML 统一软件建模工具。

    所谓建模,前面已经说过,就是用 UML 对领域业务问题和软件系统进行设计抽象,一个工

    具完成软件开发过程中的两个客观存在的建模。

    所谓语言,这个比较有意思,为什么一个建模工具被称为语言?我们先看下语言的特点,语

    言一则用以沟通,通过语言人们得以交流;

    二则用以思考,即使我们不需要和别人交流,仅

    仅一个人进行思考的时候,其实我们头脑中还是默默在使用语言,有时候甚至不知不觉说出

    来。

    UML 也符合语言的这两个特点,一方面满足设计阶段和各个相关方沟通的目的;一方面可

    以用来思考,即使软件开发过程不需要跟其他人沟通,或者还没到沟通的时候,依然可以使

    用 UML 建模画图,帮助自己进行设计思考。

    此外,语言还有个特点,就是有方言,而对于 UML,就我观察,不同公司,不同团队使用

    UML 都有自己的特点,并不需要拘泥于 UML 的规范和语法,只要不引起歧义,在使用

    UML 过程中对 UML 语法元素适当变通正是 UML 的最佳实践,这正是 UML 的”方

    言“。

    具体如何使用 UML 画图建模,如何在不同的软件设计阶段用最合适的 UML 图形进行软件

    设计与建模,以及如何将这些模型图整合起来构成一个完整的软件设计文档,我会在下一篇

    文章中为你讲述。

    最后很多做软件开发同学的职业规划都是架构师,那么设想这样一个场景,如果公司安排你做架

    构师,要你在项目开发前期进行软件架构设计,你该如何开展你的工作,你该如何输出你的

    工作成果,你如何确定你的设计是否满足用户需求,你是否有把握最后交付的软件是满足要

    求的,是否有把握让团队每个工程师清晰了解自己的职责范围并有效地完成开发工作?

    架构师的核心工作就是做好软件设计,软件设计是软件开发过程中的一个重要环节。如何进

    行软件设计,软件设计的输出是什么?软件设计过程中,如何和各个相关方沟通,使软件设

    计既能满足用户的功能需求,又能满足用户的非功能需求,也能满足用户的成本要求?此

    外,还要使开发工程师、测试工程师、运维工程师能够理解软件的整体架构、主要模块划

    分、关键技术实现、核心领域模型,使他们能做好自己的工作,使得软件在开发之初就对软

    件未来蓝图有个清晰的认识,从而使整个软件开发过程处于可控的范围之内?

    以上这些诉求可以说是软件开发管理与技术的核心诉求,这些问题搞定了,软件的开发过程

    和结果也就都得到了保证。而要实现这些诉求,主要的手段就是软件建模,以及将这些软件

    模型组织成一篇有价值的设计文档。

    相关文章
    |
    6月前
    |
    Devops 测试技术 项目管理
    软件体系结构 - 需求工程
    【4月更文挑战第3天】软件体系结构 - 需求工程
    72 11
    |
    6月前
    软件体系结构 - 系统工程【切克兰德方法】
    软件体系结构 - 系统工程【切克兰德方法】
    203 0
    |
    6月前
    |
    存储 消息中间件 算法
    软件体系结构 - 系统分析与设计(1.结构化方法)
    【4月更文挑战第5天】软件体系结构 - 系统分析与设计(1)
    149 0
    |
    6月前
    |
    存储 测试技术 BI
    软件体系结构 - 系统分析与设计(2.面向对象方法)
    【4月更文挑战第6天】软件体系结构 - 系统分析与设计(2)
    98 0
    |
    4月前
    |
    数据库
    系统分析与设计问题之什么是软件分析和软件设计
    系统分析与设计问题之什么是软件分析和软件设计
    |
    6月前
    |
    敏捷开发
    软件设计中常用的开发模型
    软件设计中常用的开发模型
    120 1
    |
    XML 消息中间件 JSON
    【架构设计 领域驱动开发 三】战略建模
    【架构设计 领域驱动开发 三】战略建模
    104 0
    |
    敏捷开发 测试技术 uml
    软件方法:业务建模和需求札记-建模和UML
    软件方法:业务建模和需求札记-建模和UML
    204 0
    《系统分析与设计方法及实践》一1.1 什么是软件
    本节书摘来华章计算机《系统分析与设计方法及实践》一书中的第1章 ,第1.1节,窦万峰 主编 宋效东 史玉梅 李东振 赵菁 等参编更多章节内容可以访问云栖社区“华章计算机”公众号查看。
    2022 0