AOP(Aspect Oriented Programming,面向切麵編程),通過預編譯方式和運行期動態代理實現程式功能的統一維護的一種技術。 ...
什麼是AOP
AOP(Aspect Oriented Programming,面向切麵編程),通過預編譯方式和運行期動態代理實現程式功能的統一維護的一種技術。
AOP的作用
利用AOP編程可以對業務邏輯的各個部分進行隔離,從而使業務邏輯各部分之間的耦合度降低(低耦合),提高程式的可重用性,提高開發效率。
AOP的功能
- 日誌記錄
- 性能統計
- 安全控制
- 事務處理
- 異常處理
- 其他功能
AOP專業術語
- 橫切關註點:在軟體開發中,分佈於應用中多處的功能被稱為橫切關註點。通常,這些橫切關註點從概念上是與應用的業務邏輯分離的(但往往直接嵌入到應用的業務邏輯之中),AOP的目標正是將這些橫切關註點與業務邏輯隔離開來。
- 連接點(Joinpoint):程式執行的某個特定位置〈如類開始初始化前、類初始化後。類某個方法調用前、調用後、方法跑吹異常後)。一個類或一段程式代碼擁有一些具有邊界性質的特定點,這些代碼中的特定點就稱為連接點(即插入代碼的位置)。
註意: Spring AoP僅支持方法的連接點,即僅能在方法調用前、方法調用後、方法拋出異常時以及方法調用前後這些程式執行點織入增強。
- 切點(Pointcut):每個類一般都擁有多個連接點(一般一個方法就是一個連接點)。AOP需要定位到特定的連接點,而定位連接點的方式稱為切點。連接點相當於資料庫中的記錄,而切點相當於查詢條件,一個切點可以匹配多個連接點。(即插入代碼位置的查詢條件)。
註意:Spring AOP中切點通過Pointcut介面定義,它使用類和方法作為連接點的查詢條件。SpringAOP的規則解析引擎負責解析切點所設定的查詢條件,找到對應的連接點。
- 增強(Advice):增強是織入到目標類連接點上的一段程式代碼。在Spring AOP中,增強除用於描述一段程式代碼外還擁有另一個和連接點相關的信息-執行點的方位。結合執行點的方位信息和切點信息,AOP就可以找到特定的連接點。因為增強既包括了用於添加到目標連接點上的一段執行邏輯,由包含用於定位連接點的方位信息,所以Spring所提供的增強介面都帶有方位名(即插入的代碼塊)。
- 引介(lntroduction):引介是一種特殊的增強,它為類添加一些屬性和方法。即使一個業務類原本沒有實現某個介面,也可以通過AOP引介功能,動態地位該業務類添加介面的實現邏輯,讓業務類成為這個介面的實現類。
- 目標對象(Target):它是增強邏輯的織入目標類。通過AOP,業務邏輯類只需要實現非橫切邏輯的代碼,而性能監視、事務管理等橫切邏輯則可以使用AOP動態織入到特定的連接點上。
- 織入(Weaving):織入是將增強添加對目標類具體連接點上的過程。
- 切麵(Aspect):切麵由切點和增強或引介組成。它既包括了橫切邏輯的定義,也包括了連接點的定義。
- 切麵=切點+增強((或引介)
註意:Spring AOP負責實施切麵的框架,它將切麵所定義的橫切邏輯織入到切麵所指定的連接點中。
AOP織入的的三種方式
- 編譯器織入:要求使用特殊的編譯器;
- 類裝載器織入:要求使用特殊的類裝載器;
- 動態代理織入:在運行期為目標類添加增強生成子類的方式。
註意:Spring AOP採用動態代理織入方式。
AOP的優點
-
AOP將橫切關註點從主業務邏輯中分離出來,使得代碼更加模塊化和可維護。通過將橫切關註點封裝為獨立的切麵,可以將其在不同的應用程式模塊中進行重覆使用,避免了代碼的重覆編寫。
-
AOP提供了一種機制,使得橫切關註點可以在應用程式的不同部分中進行重用。這樣可以減少代碼的冗餘,提高代碼的可重用性,並且在需要修改橫切關註點時,只需要修改切麵,而無需修改主業務邏輯。
-
AOP通過將橫切關註點分離出來,實現了主業務邏輯與橫切關註點的解耦。主業務邏輯只需關註核心功能的實現,而不需要關註橫切關註點的具體處理邏輯。這樣可以提高代碼的可維護性,並且方便對橫切關註點進行修改和擴展。
-
AOP可以使代碼更加簡潔和清晰。通過將橫切關註點從主業務邏輯中提取出來,主業務邏輯的代碼變得更加簡單明瞭,不再混雜著各種橫切關註點的處理邏輯。
-
AOP將橫切關註點封裝為獨立的切麵,便於管理和維護。當需要修改或調整橫切關註點時,只需修改切麵的代碼,而不需要修改主業務邏輯。這樣可以減少錯誤發生的概率,並且方便對橫切關註點進行跟蹤和調試。