舉一個(gè)最簡(jiǎn)單的例子說(shuō)明什么是面向切面編程,銀行柜員機(jī)程序,它實(shí)現(xiàn)的商業(yè)邏輯很簡(jiǎn)單,如果客戶取錢就在客戶的帳戶上做減法,如果存錢就做加法。這樣的開(kāi)發(fā)任務(wù)交給程序員他最開(kāi)心,因?yàn)檫@對(duì)他來(lái)說(shuō)小菜一碟。
而實(shí)際上銀行和客戶對(duì)只實(shí)現(xiàn)這2個(gè)功能的程序是不放心的,于是就引進(jìn)了事務(wù)處理保證操作的完整性、日志功能完成報(bào)表稽核,這時(shí)程序員就要郁悶了:要分析每一個(gè)商業(yè)邏輯,在代碼開(kāi)始的部分聲明事務(wù)開(kāi)始、代碼結(jié)束的部分聲明事務(wù)結(jié)束,還要捕獲中間發(fā)生的異常,進(jìn)行異常處理;對(duì)于涉及到資金變化的邏輯結(jié)束的時(shí)候要寫日志,這個(gè)相對(duì)簡(jiǎn)單,但是成百上千的ctrl+c\ctrl+v對(duì)程序員來(lái)說(shuō)是也是不能忍受的。
從上面的例子可以看到,我們真正需要的可能就那么一兩條代碼,而實(shí)際上我們已經(jīng)寫了一二十行。AOP就是來(lái)解決這種問(wèn)題的。讓程序員只關(guān)注核心代碼,切面代碼(上面的事務(wù)處理、日志記錄就是切面,后面還會(huì)講到)進(jìn)行模塊化。實(shí)際使用大概是這樣的:對(duì)于事務(wù)處理,程序運(yùn)行到核心代碼處,攔截器(AOP框架提供的)激活,觸發(fā)事務(wù)處理切面代碼聲明事務(wù)開(kāi)始,核心代碼結(jié)束,攔截器再次激活,觸發(fā)事務(wù)處理切面代碼事務(wù)提交。
這樣我們可以讓高級(jí)程序員先編寫事務(wù)處理切面模塊,測(cè)試通過(guò)后就可以給初級(jí)程序員用了;初級(jí)程序員們負(fù)責(zé)編寫各種各樣的商業(yè)核心邏輯代碼,測(cè)試通過(guò)后提交給配置程序員,配置程序員將商業(yè)代碼和切面模塊進(jìn)行組合配置,最后進(jìn)行合并測(cè)試,測(cè)試通過(guò),結(jié)束。按這種方式開(kāi)發(fā),方便測(cè)試、程序模塊之間低耦合、非侵入式,是不是老板開(kāi)心、程序員也開(kāi)心呢?
剛開(kāi)始看AOP的時(shí)候總是被它的那些概念搞得一頭霧水,這里是我的一些理解:
- Concern(要素):程序關(guān)注的一個(gè)區(qū)域。比如,有適合AOP的像事務(wù)處理和不適合的像產(chǎn)品組合分類(適合OOP)。
- Crosscutting Concern(橫切要素):Concern的一種,其實(shí)就是適合AOP的Concern,橫切我理解是和OOP相對(duì)的意思,OOP一般都是繼承樹(shù),而橫切就將有相同需要的類放到了一個(gè)平面進(jìn)行處理。好像父類生物,下面繼承有大白菜、豬,我們橫切這2個(gè)類,放到我們的食品工廠要進(jìn)行食品罐裝加工(第一步清洗殺菌...最后一步打印生產(chǎn)日期)這樣就分別生產(chǎn)出了韓國(guó)泡菜和午餐肉
- Aspect(切面),Crosscutting Concern的模塊化,將抽象的東西Crosscutting Concern具體了一下。如事務(wù)處理、食品罐裝加工。
- Join Point(連接點(diǎn)):程序或類執(zhí)行過(guò)程中的一個(gè)點(diǎn)。一般是核心商務(wù)邏輯的某一個(gè)方法,好像銀行柜員機(jī)程序的資金入庫(kù)方法saveMoney()。
- Advice(通知):在Join Point上執(zhí)行的一個(gè)動(dòng)作,通知一般通過(guò)攔截器調(diào)用。有這幾種類型的Advice,around(包圍型)、before、after。事務(wù)處理就是around型,日志記錄是after型。
- Pointcut(切入點(diǎn)):這個(gè)東東很有用,它是一系列的Join Point,用通配符或者正則表達(dá)式表示,比如save*表示所有以save開(kāi)頭的方法,Pointcut和Advice綁定,這樣Advice就可以通知滿足條件的一類Join Point。比如所有事務(wù)處理切面around以save開(kāi)頭和update開(kāi)頭的方法,而select開(kāi)頭的方法不受影響。
- Introduction(引入):不是很理解,以后補(bǔ)充吧。
- Target Object(目標(biāo)對(duì)象):包含Join Point的對(duì)象,也就是被就Advice的類,也就是是商務(wù)邏輯對(duì)象,比如銀行柜員機(jī)類。這個(gè)對(duì)象永遠(yuǎn)是一個(gè)被代理的對(duì)象。
- AOP Proxy(AOP代理):由AOP框架創(chuàng)建的對(duì)象,實(shí)現(xiàn)advice的執(zhí)行。
- Weaving(織入):將Aspec模塊織入核心商務(wù)邏輯,比如,將事務(wù)處理模塊和銀行柜員機(jī)程序通過(guò)配置結(jié)合起來(lái),決定什么情況下事務(wù)處理模塊被通知調(diào)用。