Spring AOP的簡(jiǎn)單理解

偶然看到一篇十分通俗易懂的文章搞监,不過(guò)原出處找不到了,這里還是分享一下。

https://blog.csdn.net/qukaiwei/article/details/50367761

一、我所知道的AOP

初看aop,上來(lái)就是一大堆術(shù)語(yǔ)惨驶,而且還有個(gè)拉風(fēng)的名字,面向切面編程敛助,都說(shuō)是OOP的一種有益補(bǔ)充等等粗卜。一下子讓你不知所措,心想著:怪不得很多人都和我說(shuō)aop多難多難纳击。當(dāng)我看進(jìn)去以后续扔,我才發(fā)現(xiàn):它就是一些java基礎(chǔ)上的樸實(shí)無(wú)華的應(yīng)用,包括ioc焕数,包括許許多多這樣的名詞测砂,都是萬(wàn)變不離其宗而已。

二百匆、為什么用AOP

  1. 為了方便,看一個(gè)國(guó)外很有名的大師說(shuō)呜投,編程的人都是“懶人”加匈,因?yàn)樗炎约鹤龅氖虑槎甲尦绦蜃隽恕S昧薬op能讓你少寫很多代碼仑荐,這點(diǎn)就夠充分了吧雕拼。
  2. 為了更清晰的邏輯,可以讓你的業(yè)務(wù)邏輯去關(guān)注自己本身的業(yè)務(wù)粘招,而不去想一些其他的事情啥寇,這些其他的事情包括:安全,事物洒扎,日志等辑甜。

三、那些AOP的術(shù)語(yǔ)

初看這么多術(shù)語(yǔ)袍冷,一下子都不好接受磷醋,慢慢來(lái),很快就會(huì)搞懂胡诗。

1. 通知(Advice)

就是你想要的功能邓线,也就是上面說(shuō)的 安全淌友,事物,日志等骇陈。你給先定義好把震庭,然后在想用的地方用一下。

2. 連接點(diǎn)(JoinPoint)

這個(gè)更好解釋了你雌,就是spring允許你使用通知的地方器联,那可真就多了,基本每個(gè)方法的前匪蝙,后(兩者都有也行)主籍,或拋出異常時(shí)都可以是連接點(diǎn),spring只支持方法連接點(diǎn).其他如aspectJ還可以讓你在構(gòu)造器或?qū)傩宰⑷霑r(shí)都行逛球,不過(guò)那不是咱關(guān)注的千元,只要記住,和方法有關(guān)的前前后后(拋出異常)颤绕,都是連接點(diǎn)幸海。

3. 切入點(diǎn)(Pointcut)

上面說(shuō)的連接點(diǎn)的基礎(chǔ)上,來(lái)定義切入點(diǎn)奥务,你的一個(gè)類里物独,有15個(gè)方法,那就有幾十個(gè)連接點(diǎn)了對(duì)把氯葬,但是你并不想在所有方法附近都使用通知(使用叫織入挡篓,以后再說(shuō)),你只想讓其中的幾個(gè)帚称,在調(diào)用這幾個(gè)方法之前官研,之后或者拋出異常時(shí)干點(diǎn)什么,那么就用切點(diǎn)來(lái)定義這幾個(gè)方法闯睹,讓切點(diǎn)來(lái)篩選連接點(diǎn)戏羽,選中那幾個(gè)你想要的方法。

4. 切面(Aspect)

切面是通知和切入點(diǎn)的結(jié)合÷コ裕現(xiàn)在發(fā)現(xiàn)了吧始花,沒(méi)連接點(diǎn)什么事情,連接點(diǎn)就是為了讓你好理解切點(diǎn)孩锡,搞出來(lái)的酷宵,明白這個(gè)概念就行了。通知說(shuō)明了干什么和什么時(shí)候干(什么時(shí)候通過(guò)方法名中的before,after躬窜,around等就能知道)忧吟,而切入點(diǎn)說(shuō)明了在哪干(指定到底是哪個(gè)方法),這就是一個(gè)完整的切面定義斩披。

5. 引入(introduction)

允許我們向現(xiàn)有的類添加新方法屬性溜族。這不就是把切面(也就是新方法屬性:通知定義的)用到目標(biāo)類中嗎

6. 目標(biāo)(target)

引入中所提到的目標(biāo)類讹俊,也就是要被通知的對(duì)象,也就是真正的業(yè)務(wù)邏輯煌抒,他可以在毫不知情的情況下仍劈,被咱們織入切面。而自己專注于業(yè)務(wù)本身的邏輯寡壮。

7. 代理(proxy)

怎么實(shí)現(xiàn)整套aop機(jī)制的贩疙,都是通過(guò)代理,這個(gè)一會(huì)給細(xì)說(shuō)况既。

8. 織入(weaving)

把切面應(yīng)用到目標(biāo)對(duì)象來(lái)創(chuàng)建新的代理對(duì)象的過(guò)程这溅。有3種方式,spring采用的是運(yùn)行時(shí)棒仍,為什么是運(yùn)行時(shí)悲靴,后面解釋。

關(guān)鍵就是:切點(diǎn)定義了哪些連接點(diǎn)會(huì)得到通知莫其。

四癞尚、我所理解的AOP原理

Spring用代理類包裹切面,把他們織入到Spring管理的bean中乱陡。也就是說(shuō)代理類偽裝成目標(biāo)類浇揩,它會(huì)截取對(duì)目標(biāo)類中方法的調(diào)用,讓調(diào)用者對(duì)目標(biāo)類的調(diào)用都先變成調(diào)用偽裝類憨颠,偽裝類中就先執(zhí)行了切面胳徽,再把調(diào)用轉(zhuǎn)發(fā)給真正的目標(biāo)bean。

現(xiàn)在可以自己想一想爽彤,怎么搞出來(lái)這個(gè)偽裝類养盗,才不會(huì)被調(diào)用者發(fā)現(xiàn)(過(guò)JVM的檢查,JAVA是強(qiáng)類型檢查淫茵,哪里都要檢查類型)。

實(shí)現(xiàn)和目標(biāo)類相同的接口——JDK動(dòng)態(tài)代理

實(shí)現(xiàn)和目標(biāo)類相同的接口蹬跃,我也實(shí)現(xiàn)和你一樣的接口匙瘪,反正上層都是接口級(jí)別的調(diào)用,這樣我就偽裝成了和目標(biāo)類一樣的類(實(shí)現(xiàn)了同一接口蝶缀,咱是兄弟了)丹喻,也就逃過(guò)了類型檢查,到j(luò)ava運(yùn)行期的時(shí)候翁都,利用多態(tài)的后期綁定(所以spring采用運(yùn)行時(shí))碍论,偽裝類(代理類)就變成了接口的真正實(shí)現(xiàn),而他里面包裹了真實(shí)的那個(gè)目標(biāo)類柄慰,最后實(shí)現(xiàn)具體功能的還是目標(biāo)類鳍悠,只不過(guò)偽裝類在之前干了點(diǎn)事情(寫日志税娜,安全檢查,事物等)藏研。

這就好比敬矩,一個(gè)人讓你辦件事,每次這個(gè)時(shí)候蠢挡,你弟弟就會(huì)先出來(lái)弧岳,當(dāng)然他分不出來(lái)了,以為是你业踏,你這個(gè)弟弟雖然辦不了這事禽炬,但是他知道你能辦,所以就答應(yīng)下來(lái)了勤家,并且收了點(diǎn)禮物(寫日志)腹尖,收完禮物了,得把事給人家辦了啊却紧,所以你弟弟又找你這個(gè)哥哥來(lái)了桐臊,最后把這是辦了的還是你自己。但是你自己并不知道你弟弟已經(jīng)收禮物了晓殊,你只是專心把這件事情做好断凶。

順著這個(gè)思路想,要是本身這個(gè)類就沒(méi)實(shí)現(xiàn)一個(gè)接口呢巫俺,你怎么偽裝我认烁,我就壓根沒(méi)有機(jī)會(huì)讓你搞出這個(gè)雙胞胎的弟弟,那么就用第2種代理方式介汹,創(chuàng)建一個(gè)目標(biāo)類的子類却嗡,生個(gè)兒子,讓兒子偽裝我

生成子類調(diào)用——CGLib動(dòng)態(tài)代理

生成子類調(diào)用嘹承,這次用子類來(lái)做為偽裝類窗价,當(dāng)然這樣也能逃過(guò)JVM的強(qiáng)類型檢查,我繼承的嘛叹卷,當(dāng)然查不出來(lái)了撼港,子類重寫了目標(biāo)類的所有方法,當(dāng)然在這些重寫的方法中骤竹,不僅實(shí)現(xiàn)了目標(biāo)類的功能帝牡,還在這些功能之前,實(shí)現(xiàn)了一些其他的(寫日志蒙揣,安全檢查靶溜,事物等)。

這次的對(duì)比就是,兒子先從爸爸那把本事都學(xué)會(huì)了罩息,所有人都找兒子辦事情嗤详,但是兒子每次辦和爸爸同樣的事之前,都要收點(diǎn)小禮物(寫日志)扣汪,然后才去辦真正的事断楷。當(dāng)然爸爸是不知道兒子這么干的了。這里就有件事情要說(shuō)崭别,某些本事是爸爸獨(dú)有的(final的)冬筒,兒子學(xué)不了,學(xué)不了就辦不了這件事茅主,辦不了這個(gè)事情舞痰,自然就不能收人家禮了。

總結(jié)

前一種兄弟模式诀姚,Spring會(huì)使用JDK的java.lang.reflect.Proxy類响牛,它允許Spring動(dòng)態(tài)生成一個(gè)新類來(lái)實(shí)現(xiàn)必要的接口,織入通知赫段,并且把對(duì)這些接口的任何調(diào)用都轉(zhuǎn)發(fā)到目標(biāo)類呀打。

后一種父子模式,Spring使用CGLIB庫(kù)生成目標(biāo)類的一個(gè)子類糯笙,在創(chuàng)建這個(gè)子類的時(shí)候贬丛,Spring織入通知,并且把對(duì)這個(gè)子類的調(diào)用委托到目標(biāo)類给涕。

相比之下豺憔,還是兄弟模式好些,他能更好的實(shí)現(xiàn)松耦合够庙,尤其在今天都高喊著面向接口編程的情況下恭应,父子模式只是在沒(méi)有實(shí)現(xiàn)接口的時(shí)候,也能織入通知耘眨,應(yīng)當(dāng)做一種例外昼榛。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市剔难,隨后出現(xiàn)的幾起案子胆屿,更是在濱河造成了極大的恐慌,老刑警劉巖钥飞,帶你破解...
    沈念sama閱讀 211,194評(píng)論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件莺掠,死亡現(xiàn)場(chǎng)離奇詭異衫嵌,居然都是意外死亡读宙,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,058評(píng)論 2 385
  • 文/潘曉璐 我一進(jìn)店門楔绞,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)结闸,“玉大人唇兑,你說(shuō)我怎么就攤上這事¤氤” “怎么了扎附?”我有些...
    開(kāi)封第一講書人閱讀 156,780評(píng)論 0 346
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)结耀。 經(jīng)常有香客問(wèn)我留夜,道長(zhǎng),這世上最難降的妖魔是什么图甜? 我笑而不...
    開(kāi)封第一講書人閱讀 56,388評(píng)論 1 283
  • 正文 為了忘掉前任碍粥,我火速辦了婚禮,結(jié)果婚禮上黑毅,老公的妹妹穿的比我還像新娘嚼摩。我一直安慰自己,他們只是感情好矿瘦,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,430評(píng)論 5 384
  • 文/花漫 我一把揭開(kāi)白布枕面。 她就那樣靜靜地躺著,像睡著了一般缚去。 火紅的嫁衣襯著肌膚如雪潮秘。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書人閱讀 49,764評(píng)論 1 290
  • 那天病游,我揣著相機(jī)與錄音唇跨,去河邊找鬼。 笑死衬衬,一個(gè)胖子當(dāng)著我的面吹牛买猖,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播滋尉,決...
    沈念sama閱讀 38,907評(píng)論 3 406
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼玉控,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了狮惜?” 一聲冷哼從身側(cè)響起高诺,我...
    開(kāi)封第一講書人閱讀 37,679評(píng)論 0 266
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤虱而,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后开泽,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,122評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,459評(píng)論 2 325
  • 正文 我和宋清朗相戀三年导俘,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片旅薄。...
    茶點(diǎn)故事閱讀 38,605評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖少梁,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情矫付,我是刑警寧澤,帶...
    沈念sama閱讀 34,270評(píng)論 4 329
  • 正文 年R本政府宣布技即,位于F島的核電站,受9級(jí)特大地震影響而叼,放射性物質(zhì)發(fā)生泄漏身笤。R本人自食惡果不足惜葵陵,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,867評(píng)論 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望脱篙。 院中可真熱鬧,春花似錦绊困、人聲如沸文搂。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 30,734評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)煤蹭。三九已至,卻和暖如春取视,著一層夾襖步出監(jiān)牢的瞬間硝皂,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 31,961評(píng)論 1 265
  • 我被黑心中介騙來(lái)泰國(guó)打工作谭, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留稽物,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 46,297評(píng)論 2 360
  • 正文 我出身青樓折欠,卻偏偏與公主長(zhǎng)得像贝或,于是被迫代替她去往敵國(guó)和親秧倾。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,472評(píng)論 2 348

推薦閱讀更多精彩內(nèi)容