UML的各种关系理解

  • 泛化关系(generalization)(IS A
    • 解释:就是继承关系,继承关系为 is-a的关系;两个对象之间如果可以用 is-a 来表示,就是继承关系:(..是..)
    • eg:IPhone5s 的类 is a IPhone5 的类 ,从哲学的角度上讲,IPhone5s类就是iPhone5类--因为它可以实在iPhone5 的类上修改而产生的,对比5而言5s只有功能的修改或者增加,并没有减少因为5的类是有具体实现(非抽象类),5s也是有具体实现(非抽象类的所以就叫继承
      同理,如果5类 和5s类都是抽象类,那也是可以称为继承的,要不就就成了实现了。【抽象到抽象,具体到具体】
    • 类图:
      image
  • 实现关系(realize)(IS A)
    • 解释: 和泛化关系(generalization)几乎一致,区别说就是 一个继承抽象类(abstract ,interface),一个继承具体类
    • eg:iPhone 类 和 iPhone 5 的类 的关系 iPhone 类是没有具体实现的,是一个抽象类,一个抽象的概念【抽象到具体】
    • 类图:
      image
  • 聚合关系(aggregation)(has-a)
    • 解释:就是由某某组成的关系,聚合关系的两个类处于不同的层次,一个是整体,一个是部分。而且各个组成部分脱离整体也是可以存在的,整体和部分的生命周期是独立的。如果有联系产生那就是Composition(组合)关系了。代码上的体现:如果A由B聚合成,表现为A包含有B的全局对象,但是B对象可以不在A创建的时刻创建
    • eg: 部门和员工,当部门解散后,员工的生命周期是不会随着部门的生命周期的结束而结束。
    • 类图:

      image
  • 组合关系(composition)(contains-a)
    • 解释:就是由某某组装而成的关系,聚合关系的两个类处于不同的层次,一个是整体,一个是部分,各个组成部分脱离整体是不可以存在的。整体和部分的生命周期是一致的。代码上的体现:如果A由B组成,表现为A包含有B的全局对象,并且B对象在A创建的时刻创建
    • eg:企业和部门,当企业倒闭后,部门也就随着企业的生命周期的结束而结束。人和四肢
    • 类图:
      image

  • 关于聚合和组合的区分:其关键点就是整体和部分的生命周期是否一致这个条件。(深入思考:当整体的生命周期结束后,不会受到质变,也不会受到任何 对生命周期有影响的改变。例如 电脑 和CPU, 相反 例如 人体 和四肢)
  • 关联关系(association)
    • 解释:它描述不同类的对象之间的结构关系,是处于同一种层次;它是一种静态关系, 通常与运行状态无关,一般由常识等因素决定的;它一般用来定义对象之间静态的、天然的结构; 所以,关联关系是一种“强关联”的关系;
      不存在依赖关系的偶然性、关系也不是临时性的,一般是长期性的。代码体现:表现在代码层面,为被关联类B以类属性的形式出现在关联类A中,也可能是关联类A引用了一个类型为被关联类B的全局变量。
    • eg:A引用了B作为属性
    • 类图:
      image
  • 依赖关系(dependency)
    • 解释:它描述不同类的对象之间的结构关系,是处于同一种层次;它是一种动态关系,与关联关系不同的是,它是一种临时性的关系,通常在运行期间产生,并且随着运行时的变化; 依赖关系也可能发生变化;
      代码体现:例如如果A依赖于B,则B体现为局部变量,方法的参数、或静态方法的调用。
    • eg:A中的方法调用了B
    • 类图:
      image
     
     
     
     
posted @ 2015-05-26 21:31  leonxi  阅读(2429)  评论(1编辑  收藏  举报