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