为什么用UML

项目需要,在项目开发实现前期进行框架技术设计(条条大路通罗马通罗马,画图或者写代码都可以,适合就可以!)。

用户的交互我们通常用Axure(原型设计)体现,

框架和功能结构设计则用UML体现,清楚自已使用目的,是否有用仁者见仁智者见智。

A:方便业务设计交流,理清思路,统一的规范描述(代码高层设计和交流的表述,避免不同表达!);

B:建模工具可以把设计直接转换为代码(基本不用,不用把精力放在“把UML用到极致“);

uml网上一搜一大堆,推荐一本书thinking in uml

把几个关键点记录下

 UML类图关系:

泛化(继承)、实现、聚合、组合、关联、依赖

泛化(继承)--用于Interface和Interface之间,或者用于Class和Class之间

实现--指的是一个class类实现interface接口(可以是多个)的功能

关联:一个类是另一个类的成员变量,可以是单向的,也可以是双向的。

依赖:三种表现形式通过形参、通过局部变量、通过静态变量。

关联与依赖区别

用斧子砍树,我和斧子之间就是一种依赖,我和同学就是一种关联。

依赖是一种弱关联,只要一个类用到另一个类,use了一个类,依赖是一种偶然的关系,比较陌生。

关联是类之间的一种关系,例如夫妻这种关系是非常明显的,比较熟悉。

聚合关系是关联关系的一种,是强的关联关系;关联和聚合在语法上无法区分

聚合关系中作为成员变量的类一般使用 set 方法赋值。

强弱排序
泛化(继承)= 实现 > 组合 > 聚合 > 关联 > 依赖

UML基本关系链接表示

  • 车是抽象的,小汽车和三轮车是车的实现关系----▽
  • BMW是小汽车的一种,需要继承继承小汽车,泛化关系(继承)——▽
  • 方向盘和发动机是小汽车一部分,是组合关系——♦
  • 公司由职员组成,公司散了人都还在,聚合关系——♢
  • 身份证代表这个具体人,人有身份证 has a,这是关联关系——>
  • 职员上班要开车或坐公交 或坐地铁,依赖关系-->

三角形为实现和泛化,表示上下关系,其中虚线为实现

菱形为聚合和组合,表示组成从属关系,其中空心为聚合

箭头为关联和依赖,表示平级关系,其中虚线为依赖

UML的基本图

静态图分为:用例图,类图,对象图,包图,构件图,部署图。

动态图分为:状态图,活动图,协作图,序列图

05-28 08:23