zoukankan      html  css  js  c++  java
  • UML图中聚合、组合、关联、依赖、泛化的强弱关系

    一、泛化

    1、说明

         泛化是一种继承关系,如果一个类A的所有属性和操作能被另一个类B所继承,则类B不仅可以包含自己独有的属性,而且可以包含类A的属性和操作。继承是类与类或者类与接口之间最常见的关系。

    2、例图

                

    3、表现

     父类 父类实例=new 子类();

    4、代码

         

    [csharp] view plain copy
     
     print?
    1. <span style="font-family:KaiTi_GB2312;font-size:24px;">class Animal{};  
    2. class Tiger:public Animal{};  
    3. class Dog:public Animal{};  
    4. Animal * pAnimal=new Dog;</span>  

    泛化中子类直接继承了父类的属性和操作所以它的关系最强

    二、关联

    1、说明

       对于两个相对独立的对象,当一个对象的实例与另一个对象的一些特定实例存在固定的对应关系时,这两个对象之间为关联关系

    2、例图

    3、表现

    关联关系时使用实例变量来实现的

    4.代码

    [csharp] view plain copy
     
     print?
    1. <span style="font-family:KaiTi_GB2312;font-size:24px;">public class Company  
    2. {  
    3.    private Employee employee()  
    4.   {  
    5.        return employee;  
    6.    }  
    7.    public void setEmployee(Employee employee)  
    8.   {  
    9.    this.employee=employee;  
    10.    }    
    11.    public void run()  
    12.   {  
    13.     employee.starWorking();  
    14.    }   
    15. }  
    16. </span>  

    三、聚合

    1、说明

       当对象A被加入到对象B中,成为对象B的组成部分时,对象B和A之间为聚集关系。聚合是关联关系的一种,是较强的关联关系,强调整体与部分之间的关系。

    2、例图

            

    3、表现

       与关联关系一样,聚合关系也是通过实例变量来实现的。
    4、关联与聚合的区别

       在语法上是难以区分的,在语义上才能更好的区分两者的区别

       区别:关联关系所涉及的两个对象是处在同一个层次上的。比如人和自行车就是一种关联关系,而不是聚合关系,因为人不是自行车的组成部分。

                  聚合关系涉及的两个对象处于不平等的层次上,一个代表整体,一个代表部分。比如:电脑和它的显示器、键盘、主板和内存就是聚集关系。

    5、代码

    [csharp] view plain copy
     
     print?
    1. <span style="font-family:KaiTi_GB2312;font-size:24px;">public class Computer  
    2. {  
    3.    private CPU cpu;  
    4.    public CPU getCPU()  
    5.   {  
    6.       return cpu;  
    7.    }  
    8.    public void setCPU(CPU cpu)  
    9.   {  
    10.     this.cpu=cpu;  
    11.    }  
    12.    //开启电脑  
    13.   public void start()  
    14.   {  
    15.    cpu.run();</span>  
    [csharp] view plain copy
     
     print?
    1. <span style="font-family:KaiTi_GB2312;font-size:24px;">   }  
    2.   
    3. }</span>  

    四、组合

    1、说明

       组合关系也是聚合关系的一种,是比聚合关系更强的关系。组合关系是不能共享的。例如人有四肢、头等

       表示类之间整体和部分的关系,组合中部分和整体具有统一的生存周期。一旦整体对象不存在,部分对象也将不存在。部分对象和整体对象之间具有共生死的感觉。

    2、例图

           

    4、代码

    [csharp] view plain copy
     
     print?
    1. <span style="font-family:KaiTi_GB2312;font-size:24px;">class Leg();  
    2. class Arm();  
    3. class Person  
    4. {  
    5.   Leg mLeg;  
    6.   Arm mArm;  
    7. };</span>  

    5、聚合和组合的区别

    a、聚合和组合都是一种结合关系,只是额外具有整体部分的含义

    b、部件的生命周期不同

         聚合关系中,整体不会拥有部件的生命周期,所以整体删除时,部件不会被删除。再者,多个整体可以共享同一个部件

         组合关系中,整体拥有部分的生命周期,所以整体删除时,部件一定会跟着删除。而且,多个整体不可以同时间共享一个部件。

    c、聚合关系是“has-a”关系,组合关系是“contain-a”关系


    所以它们的关系是:组合>聚合>关联

    五、依赖

    1、说明

       对于两个相对独立的对象,当一个对象负责构造另一个对象的实例时,或者依赖另一个对象的服务时,这两个对象之间主要体现为依赖关系

      与关联关系不同的是,依赖关系是以参数变量的形式传入到依赖类中。

      依赖是一种弱关联,只要一个类用到另一个类,但是和另一个类的关系不太明显的时候(可以说是“use”了那个类),可以把这种关系看成是依赖

    2、例图

           

    3、表现

        依赖关系表现在局部变量,方法的参数,以及对静态方法的调用

    4、代码

    [csharp] view plain copy
     
     print?
    1. <span style="font-family:KaiTi_GB2312;font-size:24px;">class Car();  
    2. class Hourse();  
    3. class Person  
    4. {  
    5.   void buy(Car car)  
    6.   {  
    7.   }  
    8.   void buy(House pHouse)  
    9.   {  
    10.    }  
    11. }  
    12. </span>  

    六、实现

      实现关系和泛化是同等的强度。

    综上所述它们之间的耦合度是:泛化=实现>组合>聚合>关联>依赖

  • 相关阅读:
    thinkphp5 tp5 命名空间 报错 Namespace declaration statement has to be the very first statement in the script
    开启 php 错误 提示 php-fpm 重启 nginx 500错误 解决办法 wdlinux lnmp 一键包 php脚本无法解析执行
    js 设置 cookie 定时 弹出层 提示层 下次访问 不再显示 弹窗 getCookie setCookie setTimeout
    php 二维数组 转字符串 implode 方便 mysql in 查询
    nginx 重启 ps -ef|grep nginx kill -HUP 主进程号
    jquery bootstrap help-block input 表单 提示 帮助 信息
    jquery 倒计时 60秒 短信 验证码 js ajax 获取
    jQuery如何获取同一个类标签的所有的值 遍历
    linux下C语言文件操作相关函数
    gcc,gdb用法
  • 原文地址:https://www.cnblogs.com/wuyifu/p/6872320.html
Copyright © 2011-2022 走看看