需求阶段
主要是通过用例图来描述系统的功能与使用场景;
对于关键的业务流程可以通过活动图描述;
如果在需求阶段就提出要和现有的某些子系统整合,那么可以通过时序图描述新系统和原来的子系统的调用关系;
可以通过简化的类图进行领域模型抽象,并描述核心领域对象之间的关系;
如果某些对象内部会有复杂的状态变化,比如用户、订单这些,可以用状态图进行描述。
概要设计阶段
通过部署图描述系统最终的物理蓝图;
通过组件图以及组件时序图设计软件主要模块及其关系;
还可以通过组件活动图描述组件间的流程逻辑;
详细设计阶段
主要输出的就是类图和类的时序图,指导最终的代码开发;
如果某个类方法内部有比较复杂的逻辑,那么可以用画方法的活动图进行描述。
备注:UML画图工具推荐,EA、draw.io
类间的6种静态关系
关联、依赖、聚合、组合、继承、泛化
关联:对于两个相对独立的对象,当一个对象的实例与另一个对象的一些特定实例存在固定的对应关系时,这两个对象之间为关联关系。关联关系分为单向关联和双向关联。在java中,单向关联表现为:类A当中使用了类B,其中类B是作为类A的成员变量。双向关联表现为:类A当中使用了类B作为成员变量;同时类B中也使用了类A作为成员变量。(实线+箭头,箭头指向关联的类)
依赖:依赖关系的定义为:对于两个相对独立的对象,当一个对象负责构造另一个对象的实例,或者依赖另一个对象的服务时,这两个对象之间主要体现为依赖关系。定义比较晦涩难懂,但在java中的表现还是比较直观的:类A当中使用了类B,其中类B是作为类A的方法参数、方法中的局部变量、或者静态方法调用。(虚线+箭头,箭头指向依赖的类)
聚合: 聚合关系是关联关系的一种,耦合度强于关联,他们的代码表现是相同的,仅仅是在语义上有所区别:关联关系的对象间是相互独立的,而聚合关系的对象之间存在着包容关系,他们之间是“整体-个体”的相互关系。例如:个人和属于他的房产是整体和个体的关系。(实线+空心菱形,菱形指向整体)
组合:相比于聚合,组合是一种耦合度更强的关联关系。存在组合关系的类表示“整体-部分”的关联关系,“整体”负责“部分”的生命周期,他们之间是共生共死的;并且“部分”单独存在时没有任何意义。(实线+实心菱形,菱形指向整体)
继承:继承表示类与类(或者接口与接口)之间的父子关系。在java中,用关键字extends表示继承关系。UML图例中,继承关系用实线+空心箭头表示,箭头指向父类。(实线+空心箭头)
实现:表示一个类实现一个或多个接口的方法。接口定义好操作的集合,由实现类去完成接口的具体操作。在java中使用implements表示。UML图例中,实现关系用虚线+空心箭头表示,箭头指向接口。(虚线+空心箭头)
耦合强弱:泛化=实现>组合>聚合>关联>依赖
来源:oschina
链接:https://my.oschina.net/u/939952/blog/3164287