Bootstrap

系统架构设计师考点—UML建模和设计模式

一、备考指南

        UML建模和设计模式主要考查的是面向对象基础知识、面向对象分析与设计、设计模式等相关知识,本章节在大纲改版之后有了较大变动,新版大纲缺少了历年真题常考的UML图、设计模式、设计原则等重要内容,但是这里我们还是必须保留这些内容,因为这些内容还比较重要。

二、重点考点

1、UML

2、设计模式

三、UML

1、UML (统一建模语言) 

      UML (统一建模语言)是一种可视化的建模语言,而非程序设计语言,支持从需求分析水的软件开发的全过程。从总体上来看,UML的结构包括构造块、公共机制和规则三个部分。

(1)构造块。UML有三种基本的构造块,分别是事物(thing)、关系(relationship)和图,事物是UML的重要组成部分,关系把事物紧密联系在一起,图是多个相互关联的事物的集合。

(2)公共机制。公共机制是指达到特定目标的公共UML方法。

(3)规则。规则是构造块如何放在一起的规定。

2.、事务

①结构事务:模型的静态部分,如类、接口、用例、构件等。

②行为事务:模型的动态部分,如交互、活动、状态机。分组事务:模型的组织部分,如包。

③注释事务:模型的解释部分,依附于一个元素或一组元素之上对其进行约束或解释的简单符号。

3、关系

①依赖:一个事务的语义依赖于另一个事务的语义的变化而变化。

②关联:是一种结构关系,描述了一组链,链是对象之间的连接。分为组合和聚合,都是部分和整体的关系,其中组合事务之间关系更强。两个类之间的关联,实际上是两个类所扮演角色的关联,因此,两个类之间可以有多个由不同角色标识的关联。

③泛化:一般/特殊的关系,子类和父类之间的关系。实现:一个类元指定了另一个类元保证执行的契约。关系UML图形代号如图。

568e8cfeaa9445c8953ed881239d5ab6.jpg

4、图

(1)类图:静态图,为系统的静态设计视图,展现一组对象、接口、协作和它们之间的关系。
UML类图如图所示。

1e22f836b6eb4a818f463ec59e6a5dcc.jpg

 (2)对象图:静态图,展现某一时刻一组对象及它们之间的关系,为类图的某一快照。在没有类图的前提下,对象图就是静态设计视图,如图。

b9a7a9df1fcd4c02afb7f04ba82d605f.jpg

 (3)用例图:静态图,展现了一组用例、参与者以及它们之间的关系。用例图中的参与者是人、硬件或其他系统可以扮演的角色;用例是参与者完成的一系列操作,用例之间的关系有扩展、包含、泛化,如图。

dcf7c06dbd3240249ded09da42e26629.jpg

(4)序列图:即顺序图,动态图,是场景的图形化表示,描述了以时间顺序组织的对象之间的交互活动。有同步消息(进行阻塞调用,调用者中止执行,等待控制权返回,需要等待返回箱
用实心三角箭头表示)、异步消息(发出消息后继续执行,不引起调用者阻塞,也不等待返回消息,由空心箭头表示)、返回消息(由从右到左的虚线箭头表示)三种,如图所示。
上方的对象对应下方箭头上的成员和方法。

c24f6173fd004e748ebb33b1a96c6660.jpg

(5)通信图:动态图,即协作图,强调参加交互的对象的组织,如图所示。

6261dde9456940e4913f0f30c71f7bc0.jpg

 (6)状态图:动态图,展现了一个状态机,描述单个对象在多个用例中的行为,包括简单状态和组合状态。转换可以通过事件触发器触发,事件触发后相应的监护条件会进行检查。状态图中转换和状态是两个独立的概念,如图方框代表状态,箭头上的代表触发事件,实心圆点为起点和终点。

e8ae3a46ee6f439ca30d3095a496e7ae.jpg

(7)活动图:动态图,是一种特殊的状态图,展现了在系统内从一个活动到另一个活动的流程。活动的分岔和汇合线是一条水平粗线。牢记图中并发分岔、并发汇合、监护表达式、分支、流等名词及含义。每个分岔的分支数代表了可同时运行的线程数。活动图中能够并行执行的是在一个分岔粗线下的分支上的活动,如图所示。

337ce7f81ce64064b0938b82473cb43e.jpg

(8)构件图(组件图):静态图,为系统静态实现视图,展现了一组构件之间的组织和依赖,如图所示。

79cdafdd7993451f94c45c5050ac477a.jpg

 (9)部署图:静态图,为系统静态部署视图,部署图物理模块的节点分布。它与构件图相关,通常一个节点包含一个或多个构件。其依赖关系类似于包依赖,因此部署组件之间的依赖是单向的,类似于包含关系,如图所示。

5e0671f8fe584ef3a95381228cf50217.jpg

5. UML4+1视图

(1)逻辑视图。逻辑视图也称为设计视图,它表示了设计模型中在架构方面具有重要意义的部分,即类、子系统、包和用例实现的子集。

(2)进程视图。进程视图是可执行线程和进程作为活动类的建模,它是逻辑视图的一次执行实例,描述了并发与同步结构。

(3)实现视图。实现视图对组成基于系统的物理代码的文件和构件进行建模。

(4)部署视图。部署视图把构件部署到一组物理节点上,表示软件到硬件的映像和分布结构。

(5)用例视图。用例视图是最基本的需求分析模型。

四、设计模式

1.层次结构

①架构模式:软件设计中的高层决策,例如,C/S结构就属于架构模式,架构模式反映了开发软件系统过程中所作的基本设计决策。

②设计模式:每一个设计模式描述了一个在我们周围不断重复发生的问题,以及该问题的解决方案的核心。这样,你就能一次又一次地使用该方案而不必做重复劳动。设计模式的核心在于提供了相关问题的解决方案,使得人们可以更加简单方便地复用成功的设计和体系结构。四个表本要素: 模式名称、问题(应该在何时使用模式)、解决方案(设计的内容)、效果(模式应用的效果)。

③惯用法:是最低层的模式,关注软件系统的设计与实现,实现时通过某种特定的程序设计语言来描述构件与构件之间的关系。每种编程语言都有它自己特定的模式,即语言的惯用法。例如引用一计数就是C++语言中的一种惯用法。

2.设计模式分类

   按设计模式的目的划分,可分为三类:创建型模式(主要是处理创建对象)、结构型模式(主要是处理类和对象的组合)、行为型模式(主要是描述类或者对象的交互行为);按设计模式的范围划分,即根据设计模式是作用于类还是作用于对象来划分,可以把设计模式分为类设计模式和对象设计模式。总览图如下。

ef4132e6ea1c476dbf9466fb312df686.jpg

 详细内容如下:

a04c2dc432754ec4a39ea0afb3133f21.jpg

aa25541414c74ae4bf6de2da41d0c619.jpg 

 

 

;