區(qū)分
AOP舅逸、OOP在字面上雖然非常類似蜘矢,但卻是面向不同領(lǐng)域的兩種設(shè)計(jì)思想揍障。OOP(面向?qū)ο缶幊?/a>)針對(duì)業(yè)務(wù)處理過(guò)程的實(shí)體及其屬性和行為進(jìn)行抽象封裝溉旋,以獲得更加清晰高效的邏輯單元劃分啤月。
而AOP則是針對(duì)業(yè)務(wù)處理過(guò)程中的切面進(jìn)行提取煮仇,它所面對(duì)的是處理過(guò)程中的某個(gè)步驟或階段,以獲得邏輯過(guò)程中各部分之間低耦合性的隔離效果谎仲。這兩種設(shè)計(jì)思想在目標(biāo)上有著本質(zhì)的差異欺抗。
上面的陳述可能過(guò)于理論化,舉個(gè)簡(jiǎn)單的例子强重,對(duì)于“雇員”這樣一個(gè)業(yè)務(wù)實(shí)體進(jìn)行封裝绞呈,自然是OOP/OOD的任務(wù)贸人,我們可以為其建立一個(gè)“Employee”類,并將“雇員”相關(guān)的屬性和行為封裝其中佃声。而用AOP設(shè)計(jì)思想對(duì)“雇員”進(jìn)行封裝將無(wú)從談起艺智。
同樣,對(duì)于“權(quán)限檢查”這一動(dòng)作片斷進(jìn)行劃分圾亏,則是AOP的目標(biāo)領(lǐng)域十拣。而通過(guò)OOD/OOP對(duì)一個(gè)動(dòng)作進(jìn)行封裝,則有點(diǎn)不倫不類志鹃。
換而言之夭问,OOD/OOP面向名詞領(lǐng)域,AOP面向動(dòng)詞領(lǐng)域曹铃。
關(guān)系
很多人在初次接觸AOP的時(shí)候可能會(huì)說(shuō)缰趋,AOP 能做到的,一個(gè)定義良好的 OOP 的接口也一樣能夠做到陕见,我想這個(gè)觀點(diǎn)是值得商榷的秘血。AOP和定義良好的 OOP 的接口可以說(shuō)都是用來(lái)解決并且實(shí)現(xiàn)需求中的橫切問(wèn)題的方法。但是對(duì)于 OOP 中的接口來(lái)說(shuō)评甜,它仍然需要我們?cè)谙鄳?yīng)的模塊中去調(diào)用該接口中相關(guān)的方法灰粮,這是 OOP 所無(wú)法避免的,并且一旦接口不得不進(jìn)行修改的時(shí)候忍坷,所有事情會(huì)變得一團(tuán)糟粘舟;AOP 則不會(huì)這樣,你只需要修改相應(yīng)的 Aspect佩研,再重新編織(weave)即可柑肴。 當(dāng)然,AOP 也絕對(duì)不會(huì)代替 OOP韧骗。核心的需求仍然會(huì)由 OOP 來(lái)加以實(shí)現(xiàn),而 AOP 將會(huì)和 OOP 整合起來(lái)零聚,以此之長(zhǎng)袍暴,補(bǔ)彼之短。