作為當(dāng)今主流的軟件開(kāi)發(fā)方法,面向?qū)ο蟪绦蛟O(shè)計(jì)已經(jīng)為廣大程序員所熟悉,什么類呀,繼承呀,多態(tài)呀等等玩意兒也用得嗖嗖的,但是為什么設(shè)計(jì)出來(lái)的大多數(shù)系統(tǒng)都很糟糕呢?這里面有兩個(gè)重要原因:一是我們的設(shè)計(jì)師對(duì)面向?qū)ο笤O(shè)計(jì)仍然沒(méi)有深刻理解,市面上的很多書(shū)也都是些沒(méi)什么工程經(jīng)驗(yàn)的“學(xué)院派”專家編寫(xiě)的,在面向?qū)ο笤O(shè)計(jì)的理論上仍然沒(méi)什么完整理論系統(tǒng)出來(lái),有的只是一些零零星星的建議。另一個(gè)原因是目前的面向?qū)ο笳Z(yǔ)言對(duì)面向?qū)ο笤O(shè)計(jì)的支持也不夠完整,尤其是對(duì)關(guān)系的描述。面向?qū)ο笤O(shè)計(jì)的核心思想不是什么什么類呀,繼承呀,多態(tài)呀等概念,甚至完全拋棄這些東西,依然可以設(shè)計(jì)一個(gè)優(yōu)秀的面向?qū)ο蟮能浖到y(tǒng)。面向?qū)ο笤O(shè)計(jì)的核心思想是面向自然的設(shè)計(jì),即通過(guò)識(shí)別和表達(dá)出系統(tǒng)中對(duì)象、對(duì)象間的關(guān)系、對(duì)象的狀態(tài)遷移等關(guān)鍵因素,軟件設(shè)計(jì)達(dá)到自然的、正確的描述目標(biāo)系統(tǒng)的目的,這種自然的設(shè)計(jì)忠實(shí)反映了目標(biāo)系統(tǒng)中的對(duì)象和他們之間的關(guān)系以及他們之間的交互過(guò)程,是自然系統(tǒng)到軟件系統(tǒng)的自然的映射。任何一個(gè)自然系統(tǒng)都是由一些對(duì)象組成,這些對(duì)象有自己的屬性、行為和事件。任何一個(gè)系統(tǒng)都是不停運(yùn)轉(zhuǎn)的,所以光有對(duì)象還不夠,這些對(duì)象要互動(dòng)起來(lái),才能讓整個(gè)系統(tǒng)運(yùn)轉(zhuǎn),因此這些對(duì)象內(nèi)部的狀態(tài)會(huì)遷移,對(duì)象之間會(huì)有交互,這樣對(duì)象之間就產(chǎn)生了某種關(guān)系。那么究竟有些什么樣的關(guān)系呢?可以把關(guān)系分為三種類型,第一種是組合關(guān)系,也就是HAS-A關(guān)系;第二種是關(guān)聯(lián)關(guān)系,表示對(duì)象間存在某種關(guān)系,如師生關(guān)系、父子關(guān)系等;第三種是認(rèn)識(shí)關(guān)系,表示一個(gè)對(duì)象知道另一個(gè)對(duì)象的一些情況,它可以使用它知道的對(duì)象,比如學(xué)生對(duì)象知道有個(gè)公告板對(duì)象,也知道用它可以貼布告,因此,當(dāng)學(xué)生想發(fā)布告的時(shí)候就使用一下公告板對(duì)象,但學(xué)生對(duì)象并不需要持有一個(gè)公告板對(duì)象,它僅需要知道從哪兒可以得到公告板對(duì)象就行了,這是最弱的一種關(guān)系。有人可能要問(wèn)了,為什么沒(méi)有IS-A關(guān)系呢?那是因?yàn)?/span>IS-A關(guān)系本來(lái)就不是自然系統(tǒng)中的關(guān)系,它只是人們?cè)谡J(rèn)識(shí)論中的一個(gè)概念。分類、繼承這些都是認(rèn)識(shí)論的概念,很多設(shè)計(jì)師把它們和自然系統(tǒng)中的對(duì)象、關(guān)系混為一談,隨意的設(shè)計(jì)類、濫用繼承正是當(dāng)今糟糕的所謂的面向?qū)ο蟮能浖a(chǎn)生的根源。規(guī)范化面向?qū)ο筌浖O(shè)計(jì)就是識(shí)別、描述了目標(biāo)系統(tǒng)中所有有效的對(duì)象、對(duì)象狀態(tài)、對(duì)象間關(guān)系、對(duì)象交互過(guò)程的設(shè)計(jì),在保證正確反映目標(biāo)系統(tǒng)的前提下,仔細(xì)設(shè)計(jì)類接口,這才是正確的設(shè)計(jì)之道。
轉(zhuǎn)載同事博客里的一篇文章,好像說(shuō)的是我,呵呵,臉紅一下。引以為戒。