AOP編程全解析
作者:Owen-Jia
來(lái)源:SegmentFault 思否社區(qū)
AOP是一種編程思想,一套規(guī)范。
軟件開(kāi)發(fā)經(jīng)歷了面向過(guò)程編程時(shí)代,以C語(yǔ)言為代表,之后是面向?qū)ο缶幊虝r(shí)代,以Java語(yǔ)言為代表。
在21世紀(jì)大牛們又提出了一種新的編程思想面向方面編程,即AOP理念,全稱Aspect-Oriented Programming。
AOP是第三代編程思想,到哪免不了都要問(wèn)下。
發(fā)展歷史
1997年在面向?qū)ο缶幊檀髸?huì)上Gregor Kiczales等人首次提出了AOP的概念,之后各大公司等分別加入研究。2001年P(guān)alo Alto研究中心發(fā)布了首個(gè)支持AOP的語(yǔ)言AspectJ,同時(shí)也是一個(gè)規(guī)范。
目標(biāo)定位
在對(duì)真實(shí)世界抽象的面向?qū)ο缶幊踢^(guò)程中,始終伴隨著某寫(xiě)操作的代碼無(wú)法實(shí)現(xiàn)模塊化封裝,會(huì)散落在各個(gè)對(duì)象中存在,特別是非功能性代碼。對(duì)于一般的功能開(kāi)發(fā)采取面向?qū)ο蠓绞竭M(jìn)行抽象是能夠很好應(yīng)付的,但是面向方面(切面)給了一種新的思維方式來(lái)考慮編程,能更好的進(jìn)行全局結(jié)構(gòu)化思考。
所以AOP主要解決兩個(gè)問(wèn)題:
代碼分散問(wèn)題,特別是那些非功能性代碼。 作為面向?qū)ο缶幊趟季S的一種補(bǔ)充和完善。

核心知識(shí)點(diǎn)
連接點(diǎn):join point,程序的一個(gè)執(zhí)行點(diǎn),如類中的一個(gè)方法,方法里面一個(gè)代碼塊。
切入點(diǎn):point cut,是一個(gè)捕獲連接點(diǎn)的代碼結(jié)構(gòu),就是定義一個(gè)代碼邏輯用來(lái)捕獲某個(gè)連接點(diǎn)的代碼。
方面;aspect,是具體被執(zhí)行的切面邏輯代碼,類似于一個(gè)類。
通知:advice,是point cut執(zhí)行的代碼,定義在連接點(diǎn)什么時(shí)機(jī)來(lái)執(zhí)行aspect。
主要運(yùn)用場(chǎng)景
場(chǎng)景分為2類:
一類是非功能性需求,如日志、異常、安全、事務(wù)都可以使用AOP思想編程。
另一類是功能性需求,在原來(lái)對(duì)象抽象的思維中添加AOP思維,這里是一種結(jié)構(gòu)化思維,在定義類時(shí)考慮多個(gè)類的切面共性。

主流AOP語(yǔ)言實(shí)現(xiàn)
對(duì)AOP實(shí)現(xiàn)除了AspectJ外,已知的還有JBoss AOP、Spring AOP等。
這里只介紹AspectJ和SpringAOP,重點(diǎn)是他們不同點(diǎn)。
AspcetJ
AspectJ采用靜態(tài)織入方式進(jìn)行切面織入原代碼,提供獨(dú)立的編譯器把切面和原代碼的java文件編織成一個(gè)新的class文件。提供了詳細(xì)的編譯日志和調(diào)試工具,編譯時(shí)間長(zhǎng)但是運(yùn)行效率高。
連接點(diǎn)的支持范圍:
方法和構(gòu)造器調(diào)用 方法和構(gòu)造器執(zhí)行 屬性訪問(wèn) 異常處理 類初始化,是static代碼塊 語(yǔ)法結(jié)構(gòu) 控制流 對(duì)象及參數(shù)類型 條件測(cè)試
關(guān)聯(lián)連接點(diǎn)通知方式:
before,連接點(diǎn)執(zhí)行前運(yùn)行 after,連接點(diǎn)執(zhí)行后運(yùn)行 around,連接點(diǎn)的整個(gè)外側(cè),整個(gè)包住,能夠絕的連接點(diǎn)執(zhí)行和修改上下文環(huán)境
Spring AOP
Spring AOP沒(méi)有完全實(shí)現(xiàn)AspectJ語(yǔ)言,它更多的是對(duì)Spring framwork進(jìn)行Aop能力的擴(kuò)展實(shí)現(xiàn),補(bǔ)全Spring framework的不足并讓Aop與Spring framwork融合。
連接點(diǎn)只支持方法攔截調(diào)用。
連接點(diǎn)通知方式在aspect的before、after、around的基礎(chǔ)上增加throw對(duì)異常的觸發(fā)的攔截。
Spring AOP與Spring IoC體系融合,對(duì)于aspect類統(tǒng)一交由Spring beans管理,并且提供ProxyFactoryBean的AOP代理工廠類,還有自動(dòng)代理的BeanNameAutoProxyCreator和DefaultAdvisorAutoProxyCreator的強(qiáng)大工具。
Spring AOP是動(dòng)態(tài)織入,在運(yùn)行時(shí)完成AOP的aspect代碼織入原代碼邏輯中。其底層默認(rèn)采用JDK的動(dòng)態(tài)代理實(shí)現(xiàn)AOP代理,當(dāng)對(duì)象沒(méi)有實(shí)現(xiàn)接口時(shí),CGLIB會(huì)默認(rèn)使用。
優(yōu)缺點(diǎn)
優(yōu)點(diǎn):解決代碼散亂問(wèn)題、代碼邏輯解偶、易于維護(hù)、提供擴(kuò)展性和可重用性。
缺點(diǎn):切面越多系統(tǒng)越復(fù)雜難懂、工程師學(xué)習(xí)成本增加(業(yè)務(wù)不再是線型,變成了跳躍式)
AOP編程要慎重使用,作為面向?qū)ο缶幊痰囊环N補(bǔ)充。
