AOP(面向切面程式設計)

小強不砍樹發表於2023-10-04

什麼是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將橫切關注點封裝為獨立的切面,便於管理和維護。當需要修改或調整橫切關注點時,只需修改切面的程式碼,而不需要修改主業務邏輯。這樣可以減少錯誤發生的機率,並且方便對橫切關注點進行跟蹤和除錯。

相關文章