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