亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 課堂 > 技術開發 > 正文

面向對象UML中類的關系探討

2023-06-18 12:51:35
字體:
來源:轉載
供稿:網友

如果你確定兩件對象之間是is-a的關系,那么此時你應該使用繼承;比如菱形、圓形和方形都是形狀的一種,那么他們都應該從形狀類繼承而不是聚合。如果你確定兩件對象之間是has-a的關系,那么此時你應該使用聚合;比如電腦是由顯示器、CPU、硬盤等組成的,那么你應該把顯示器、CPU、硬盤這些類聚合成電腦類,而不是從電腦類繼承。

類間的關系

網上關于此類的討論非常多,發現對于該問題的理解各有各的說法,而各個說法中又相去甚遠。通過瀏覽這些討論以及對《O'Reilly - UML 2.0 In A Nutshell (2007)》的參考,發表一下自己的看法

類間關系有很多種,在大的類別上可以分為兩種:縱向關系、橫向關系。

縱向關系就是繼承關系,它的概念非常明確,也成為OO的三個重要特征之一,這里不過多的討論。

橫向關系較為微妙,按照UML的建議大體上可以分為四種:

(1)依賴    (Dependency)

(2)關聯    (Association)

(3)聚合    (Aggregation)

(4)組合    (Composition)

它們的強弱關系是沒有異議的:依賴 < 關聯 < 聚合 < 組合

然而它們四個之間的差別卻又不那么好拿捏,需要好好體會。

1、依賴

UML表示法:虛線 + 箭頭

關系:" ... uses a ..."

此關系最為簡單,也最好理解,所謂依賴就是某個對象的功能依賴于另外的某個對象,而被依賴的對象只是作為一種工具在使用,而并不持有對它的引用。

典型的例子很多,比如:

class Human
{
    public void breath()
    {
        Air freshAir = new Air();
        freshAir.releasePower();
    }
    public static void main()
    {
        Human me = new Human();
        while(true)
        {
            me.breath();
        }
    }
}

class Air
{
    public void releasePower()
    {
        //do sth.
    }
}
 

釋義:一個人自創生就需要不停的呼吸,而人的呼吸功能之所以能維持生命就在于吸進來的氣體發揮了作用,所以說空氣只不過是人類的一個工具,而人并不持有對它的引用。

2、關聯

UML表示法:實線 + 箭頭

關系:" ... has a ..."

所謂關聯就是某個對象會長期的持有另一個對象的引用,而二者的關聯往往也是相互的。關聯的兩個對象彼此間沒有任何強制性的約束,只要二者同意,可以隨時解除關系或是進行關聯,它們在生命期問題上沒有任何約定。被關聯的對象還可以再被別的對象關聯,所以關聯是可以共享的。

典型的例子很多,比如:

class Human
{
    ArrayList friends = new ArrayList();
    public void makeFriend(Human human)
    {
        friends.add(human);
    }
    public static void main()
    {
        Human me = new Human();
        while(true)
        {
            me.makeFriend(mySchool.getStudent());
        }
    }
}

釋義:人從生至死都在不斷的交朋友,然而沒有理由認為朋友的生死與我的生死有必然的聯系,故他們的生命期沒有關聯,我的朋友又可以是別人的朋友,所以朋友可以共享。

3、聚合:  

UML表示法:空心菱形 + 實線 + 箭頭

關系:" ... owns a ..."

聚合是強版本的關聯。它暗含著一種所屬關系以及生命期關系。被聚合的對象還可以再被別的對象關聯,所以被聚合對象是可以共享的。雖然是共享的,聚合代表的是一種更親密的關系。

典型的例子很多,比如:

class Human
{
    Home myHome;
    public void goHome()
    {
        //在回家的路上
        myHome.openDoor();
        //看電視
    }
    public static void main()
    {
        Human me = new Human();
        while(true)
        {
            //上學
            //吃飯
            me.goHome();
        }
    }
}

釋義:我的家和我之間具有著一種強烈的所屬關系,我的家是可以分享的,而這里的分享又可以有兩種。其一是聚合間的分享,這正如你和你媳婦兒都對這個家有著同樣的強烈關聯;其二是聚合與關聯的分享,如果你的朋友來家里吃個便飯,估計你不會給他配一把鑰匙。

4、組合

UML表示法:實心菱形 + 實線 + 箭頭

關系:" ... is a part of  ..."

組合是關系當中的最強版本,它直接要求包含對象對被包含對象的擁有以及包含對象與被包含對象生命期的關系。被包含的對象還可以再被別的對象關聯,所以被包含對象是可以共享的,然而絕不存在兩個包含對象對同一個被包含對象的共享。

典型的例子很多,比如:

class Human
{
    Heart myHeart = new Heart();
    public static void main()
    {
        Human me = new Human();
        while(true)
        {
            myHeart.beat();
        }
    }
}

釋義:組合關系就是整體與部分的關系,部分屬于整體,整體不存在,部分一定不存在,然而部分不存在整體是可以存在的,說的更明確一些就是部分必須創生于整體創生之后,而銷毀于整體銷毀之前。部分在這個生命期內可以被其它對象關聯甚至聚合,但有一點必須注意,一旦部分所屬于的整體銷毀了,那么與之關聯的對象中的引用就會成為空引用,這一點可以利用程序來保障。心臟的生命期與人的生命期是一致的,如果換個部分就不那么一定,比如闌尾,很多人在創生后的某個時間對其厭倦便提前銷毀了它,可它和人類的關系不可辯駁的屬于組合。

在UML中存在一種特例,就是允許被包含對象在包含對象銷毀前轉移給新的對象,這雖然不自然,但它給需要心臟移植的患者帶來了福音。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
中国人与牲禽动交精品| 国产精品精品一区二区三区午夜版| 亚洲欧洲免费视频| 精品久久国产精品| 在线亚洲国产精品网| 亚洲一区二区免费在线| 91久久精品国产91久久性色| 久久免费在线观看| 欧美国产第二页| 一本色道久久综合亚洲精品小说| 一级做a爰片久久毛片美女图片| 亚洲mm色国产网站| 欧美综合在线观看| 亚洲欧美中文日韩在线v日本| 91av在线国产| 97激碰免费视频| 成人午夜激情网| 欧美视频中文字幕在线| 日韩在线免费观看视频| 亚洲一区www| 亚洲高清色综合| 成人网在线免费看| 91地址最新发布| 欧美视频国产精品| 这里只有精品视频在线| 欧美日韩中国免费专区在线看| 精品国产一区二区三区久久久狼| 精品无人区乱码1区2区3区在线| 午夜精品美女自拍福到在线| 亚洲一区二区自拍| 国产精品第一视频| 亚洲精品视频播放| 欧美乱大交xxxxx另类电影| 国产精品久久999| 国语自产偷拍精品视频偷| 日韩中文字幕国产精品| 国产视频在线观看一区二区| 国产精品jvid在线观看蜜臀| 一区二区三区日韩在线| 久久噜噜噜精品国产亚洲综合| 日本国产精品视频| 国产欧美精品va在线观看| 成人午夜在线视频一区| 亚洲精品少妇网址| 综合网日日天干夜夜久久| 日韩在线播放av| 国产97在线亚洲| 精品偷拍各种wc美女嘘嘘| 51午夜精品视频| 久久久久久久久国产| 久久久久国产视频| 亚洲免费一级电影| 久久久精品视频在线观看| 久久精品国产欧美激情| 久久精品国产一区| 亚洲国产天堂久久综合网| 亚洲激情免费观看| 亚洲精品色婷婷福利天堂| 成人综合国产精品| 欧美最猛性xxxx| 亚洲天堂开心观看| 91九色视频导航| 亚洲免费视频一区二区| 欧美综合国产精品久久丁香| 91在线色戒在线| 亚洲va久久久噜噜噜| 国产在线拍偷自揄拍精品| 97精品视频在线播放| 97在线观看视频| 日韩专区中文字幕| 成人免费观看a| 亚洲精品久久久久久久久久久久| 久久久国产精品x99av| 国产日本欧美一区二区三区在线| 精品久久久精品| 国产成人福利网站| 97在线视频免费看| 久久久久久亚洲精品| 久久深夜福利免费观看| 日韩中文字幕av| 国产精品第一视频| 欧美国产精品va在线观看| 国产精品美女www爽爽爽视频| 国产成人精品在线观看| 精品国产欧美一区二区五十路| 97av视频在线| 欧美高清在线播放| 日韩av影院在线观看| 欧美精品免费播放| 亚洲精品成人久久久| 国产不卡视频在线| 精品久久久久久久久久久久久| 91天堂在线观看| 这里只有精品视频在线| 亚洲97在线观看| 欧美日韩国产综合新一区| 亚洲欧美日韩精品久久| 97碰碰碰免费色视频| 91九色视频导航| 欧美小视频在线观看| 亚洲精品xxxx| 国产精品久久久久久久久久久新郎| 日韩视频免费中文字幕| 亚洲精品成人免费| 国产一区二区丝袜高跟鞋图片| 久久精品91久久香蕉加勒比| 91国语精品自产拍在线观看性色| 亚洲国产精品久久91精品| 综合网中文字幕| 亚洲黄色av女优在线观看| 自拍偷拍免费精品| 中文字幕久久久av一区| 久久久国产一区| 日韩精品视频在线观看网址| 国产精品扒开腿做爽爽爽视频| 日韩精品高清在线观看| 亚州精品天堂中文字幕| 韩国美女主播一区| 亚洲一区二区免费在线| 久久亚洲精品一区二区| 日本一区二三区好的精华液| 91精品久久久久久久久久久久久| 国产视频丨精品|在线观看| 欧美日韩国产黄| 久久久久久这里只有精品| 久久国产精品偷| 国产精品视频1区| 欧美成人精品影院| 亚洲精品一区二区久| 国产美女高潮久久白浆| 亚洲精品电影网在线观看| 亚洲一区二区三区成人在线视频精品| 国产精品午夜国产小视频| 国产精品久久久久久av下载红粉| 热草久综合在线| 欧美黑人又粗大| 色777狠狠综合秋免鲁丝| 国产精品99久久久久久人| 久久久久久久一区二区三区| 69久久夜色精品国产69乱青草| 日韩免费高清在线观看| 国产精品黄视频| 欧美黑人性视频| 国内免费久久久久久久久久久| 欧美精品午夜视频| 精品中文字幕在线观看| 欧美性理论片在线观看片免费| 中文字幕日本欧美| 色av吧综合网| 日韩精品亚洲精品| 91久久久精品| 91九色综合久久| 久久久黄色av| 中文字幕日韩在线播放| 国产一区二区三区三区在线观看| 成人疯狂猛交xxx| 26uuu久久噜噜噜噜| 国产精品青草久久久久福利99| 国产精品成久久久久三级| 色www亚洲国产张柏芝| 国产成人自拍视频在线观看| 欧美夫妻性生活xx| 欧美精品福利视频| 欧美性xxxxxx|