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

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

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