架構(gòu)設(shè)計(jì) 是一個(gè)非常大的話題,不管寫幾篇文章,接觸到的始終只是冰山一角,更多的是實(shí)踐中去體會(huì)。
??? 這篇文章主要介紹的是面向?qū)ο驩O,面向方面AOP,面向服務(wù)SOA這三個(gè)要素在架構(gòu)設(shè)計(jì)中的位置與作用。
??? 一、架構(gòu)設(shè)計(jì)三個(gè)維度
??? 架構(gòu)設(shè)計(jì)有三個(gè)維度,或者說(shuō)是我們?cè)诳紤]架構(gòu)時(shí)需要思考的三個(gè)方向。分別為:面向?qū)ο蟆⒚嫦蚍矫妗⒚嫦蚍?wù)。這三個(gè)維度可以看作是正交的,但不同維度會(huì)互相印證,互相支撐。
??? 整個(gè)架構(gòu)的示意圖如下所示:
??? 二、面向?qū)ο?
??? 面向?qū)ο蠹夹g(shù)最初是從面向?qū)ο蟮某绦蛟O(shè)計(jì)開(kāi)始的,它的出現(xiàn)以60年代simula語(yǔ)言為標(biāo)志,并在Smalltalk語(yǔ)言的完善和標(biāo)準(zhǔn)化過(guò)程中得到更多的 擴(kuò)展和對(duì)以前的思想的重新注解。80年代中后期,面向?qū)ο蟪绦蛟O(shè)計(jì)逐漸成熟,被計(jì)算機(jī)界理解和接受,人們又開(kāi)始進(jìn)一步考慮面向?qū)ο蟮拈_(kāi)發(fā)問(wèn)題。直到現(xiàn)在, 面向?qū)ο笠呀?jīng)成為一種非常流行的編程方式,以及軟件設(shè)計(jì)的架構(gòu)。
??? 面向?qū)ο筇岢鲇腥齻€(gè)主要目標(biāo):重用性、靈活性和擴(kuò)展性,強(qiáng)調(diào)對(duì)象的“抽象”、“封裝”、“繼承”、“多態(tài)”。它能讓人們以更加接近于現(xiàn)實(shí)世界的方式來(lái)思考程序,這點(diǎn)可以說(shuō)是面向?qū)ο笞畲蟮倪M(jìn)步。
??? 在OO思想的運(yùn)用上,業(yè)界出現(xiàn)了很多好的經(jīng)驗(yàn)與技巧,從而涌現(xiàn)出大量的設(shè)計(jì)模式。可以說(shuō)面向?qū)ο笫窍到y(tǒng)分析與設(shè)計(jì)時(shí)的一個(gè)很重要的方面。
??? 三、面向方面
??? 面向方面最初來(lái)源于hook技術(shù),本質(zhì)上就是滿足擴(kuò)展的需求,可以在程序中自由擴(kuò)展功能。
??? 面向方面不僅僅是一門編程技術(shù),同樣也是一種架構(gòu)設(shè)計(jì)的思路。如果說(shuō)OO是縱向地分析、切割整個(gè)系統(tǒng),那么可以認(rèn)為AOP是橫向地對(duì)系統(tǒng)作切片。簡(jiǎn)單地理 解,OO與AOP分別從兩個(gè)不同的角度給我們提供了分析系統(tǒng)的思路。面向方面可以彌補(bǔ)面向?qū)ο蟮娜毕荩瑑煞N方式有機(jī)的結(jié)合在一起可以更加有效地分析系統(tǒng)。
??? 我們認(rèn)為OO是接近于人類認(rèn)識(shí)自然的思維方式,但對(duì)于東方來(lái)說(shuō)卻并不是這樣。當(dāng)西方人看到一個(gè)復(fù)雜系統(tǒng)的時(shí)候,只會(huì)有一種思路,就是“分解”——將系統(tǒng)分 解成一塊一塊,然后每個(gè)部分作研究。當(dāng)東方人看到一個(gè)復(fù)雜系統(tǒng)的時(shí)候,更多地會(huì)關(guān)注系統(tǒng)中存在的關(guān)系,將系統(tǒng)作為一個(gè)有機(jī)的整體進(jìn)行研究。
??? 這兩種思維方式都沒(méi)有問(wèn)題,結(jié)合起來(lái)的話分析問(wèn)題解決問(wèn)題會(huì)更好。面向?qū)ο笈c面向方面也同樣如此,都能對(duì)應(yīng)到人類認(rèn)識(shí)自然的思維方式上。不過(guò) 中國(guó) 人理解AOP可能會(huì)有不同的感悟——我寫的文章《讀易[13]·閑談中醫(yī)與AOP》有簡(jiǎn)單的說(shuō)明。
??? 四、面向服務(wù)
??? 面向服務(wù)可以說(shuō)是最近炒得比較火的概念了。包括現(xiàn)在提到的SaaS——Software as a service,軟件即服務(wù)。準(zhǔn)確說(shuō)來(lái),面向服務(wù)不僅僅是軟件行業(yè)的概念。這個(gè)要從社會(huì)的產(chǎn)業(yè)結(jié)構(gòu)說(shuō)起。
??? 社會(huì)產(chǎn)業(yè)總共分為三個(gè),第一產(chǎn)業(yè)農(nóng)業(yè),第二產(chǎn)業(yè)工業(yè),第三產(chǎn)業(yè)服務(wù)業(yè)。最早社會(huì)的主要產(chǎn)業(yè)是第一產(chǎn)業(yè)農(nóng)業(yè),將近有幾萬(wàn)年的歷史。十八世紀(jì)下半葉在英國(guó)開(kāi)始的工業(yè)革命,對(duì)人們的生活產(chǎn)生了根本性的影響,社會(huì)的主要產(chǎn)業(yè)成了第二產(chǎn)業(yè)工業(yè)。
??? 現(xiàn)在仍然屬于工業(yè)時(shí)代,或者有人說(shuō)的“后工業(yè)時(shí)代”。而在后工業(yè)時(shí)代,社會(huì)的 經(jīng)濟(jì) 體制必定要向第三產(chǎn)業(yè)服務(wù)業(yè)逐漸轉(zhuǎn)型。面向服務(wù)其實(shí)是社會(huì)經(jīng)濟(jì)體制重心的一種遷移。
??? 還是說(shuō)回到軟件行業(yè),社會(huì)的主要產(chǎn)業(yè)將轉(zhuǎn)變成服務(wù)業(yè),自然軟件行業(yè)也會(huì)出現(xiàn)對(duì)應(yīng)的變化,那就是這里提到的面向服務(wù)。面向服務(wù)今后會(huì)影響到軟件的交付模式,會(huì)對(duì)整個(gè)軟件行業(yè)的體制產(chǎn)生影響。
??? 而說(shuō)到架構(gòu)層面,面向服務(wù)是系統(tǒng)發(fā)布功能的一種方式。并且基于這種方式下不同的系統(tǒng)之間能有效地通信、協(xié)作。常見(jiàn)的實(shí)現(xiàn)技術(shù)就是Web Service。
??? 五、軟件全局觀
??? 軟件架構(gòu)設(shè)計(jì)的三個(gè)維度:面向?qū)ο蟆⒚嫦蚍矫妗⒚嫦蚍?wù)。
??? 最年長(zhǎng)的一個(gè)維度就是面向?qū)ο螅l(fā)展了好幾十年,也是相對(duì)來(lái)說(shuō)比較成熟的一個(gè)維度。它解決的問(wèn)題是系統(tǒng)內(nèi)部結(jié)構(gòu)的設(shè)計(jì)。
??? 面向方面的思想提出來(lái)能夠彌補(bǔ)面向?qū)ο蟮娜毕荨C嫦驅(qū)ο蟮姆绞讲荒軐?shí)現(xiàn)橫切關(guān)注點(diǎn)的分離,而面向方面正是為了解決這個(gè)問(wèn)題。面向方面與面向?qū)ο笠粯佣际墙鉀Q系統(tǒng)內(nèi)部結(jié)構(gòu)的設(shè)計(jì)。
??? 面向服務(wù)更多的是涉及到系統(tǒng)的外部,簡(jiǎn)單地說(shuō)就是發(fā)布功能。它并不關(guān)注系統(tǒng)內(nèi)部結(jié)構(gòu)的實(shí)現(xiàn),所以說(shuō)面向服務(wù)與面向?qū)ο蠡蛘呙嫦蚍矫娌⒉粵_突。
??? 這三個(gè)維度并不是絕對(duì)孤立的,它們之間會(huì)互相影響、制約。我們?cè)诜治黾軜?gòu)的時(shí)候需要同時(shí)考慮到這三個(gè)維度的問(wèn)題。這樣有助于我們?cè)O(shè)計(jì)出更加優(yōu)秀的架構(gòu)。
更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號(hào)聯(lián)系: 360901061
您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺(jué)我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長(zhǎng)非常感激您!手機(jī)微信長(zhǎng)按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對(duì)您有幫助就好】元
